When you install Gravitee API Management (APIM) with Docker Compose, you can install custom plugins and control the location of the persistent data.
- You must install Docker. For more information about installing Docker, go to Install Docker Engine.
- If you are deploying the Enterprise Edition of Gravitee, ensure that you have your license key. For more information about license keys, see Gravitee Platform Pricing.
-
Create the following directory structure
{% code overflow="wrap" %}
gravitee ├── apim-gateway │ ├── logs │ └── plugins ├── apim-management-api │ ├── logs │ └── plugins ├── apim-management-ui │ └── logs ├── apim-portal-ui │ └── logs ├── elasticsearch │ └── data └── mongodb └── data
{% endcode %}
mkdir -p gravitee/apim-gateway/logs, \ gravitee/apim-gateway/plugins, \ gravitee/apim-management-api/logs, \ gravitee/apim-management-api/plugins, \ gravitee/apim-management-ui/logs, \ gravitee/apim-portal-ui/logs, \ gravitee/elasticsearch/data, \ gravitee/mongodb/data
-
Download the
docker-compose.yml
file asdocker-compose-apim.yml
using the following command:curl -L https://bit.ly/docker-apim-4x -o docker-compose-apim.yml
-
To ensure that the
docker-compose-apim.yml
uses thegravitee
directory structure, follow the following sub-steps:-
In a text editor, open
docker-compose-apim.yml
-
Remove the following lines of code:
{% code overflow="wrap" %}
volumes: data-elasticsearch: data-mongo:
{% endcode %}
-
Change
$services.mongodb.volumes
to the following code:{% code overflow="wrap" %}
volumes: - ./mongodb/data:/data/db # Access the MongoDB container logs with: docker logs gio_apim_mongodb
{% endcode %}
-
Change
$services.elasticsearch.volumes
to the following code:{% code overflow="wrap" %}
volumes: - ./elasticsearch/data:/usr/share/elasticsearch/data # Access the Elasticsearch container logs with: docker logs gio_apim_elasticsearch
{% endcode %}
-
Add the following lines to
$services.gateway
:{% code overflow="wrap" %}
volumes: - ./apim-gateway/logs:/opt/graviteeio-gateway/logs - ./apim-gateway/plugins:/opt/graviteeio-gateway/plugins-ext
{% endcode %}
-
Remove
$services.management_api.links
. -
Add the following lines to
$services.management_api.environment
:{% code overflow="wrap" %}
- gravitee_plugins_path_0=/opt/graviteeio-management-api/plugins - gravitee_plugins_path_1=/opt/graviteeio-management-api/plugins-ext
{% endcode %}
-
Add the following lines to
$services.management_api
:volumes: - ./apim-management-api/logs:/opt/graviteeio-management-api/logs - ./apim-management-api/plugins:/opt/graviteeio-management-api/plugins-ext
-
Add the following lines to
$services.management_ui
:volumes: - ./apim-management-ui/logs:/var/log/nginx
-
Add the following lines to
$services.portal_ui
:volumes: - ./apim-portal-ui/logs:/var/log/nginx
-
-
(Optional) If you are using the Enterprise Edition (EE) of Gravitee APIM, add your license key by following the following steps:
-
Copy your license key to
/gravitee/license.key.
-
In a text editor, open the
docker-compose-apim.yml
file. -
Navigate to
$services.gateway.volumes
, and then add the following line of code:- ./license.key:/opt/graviteeio-gateway/license/license.key
-
Navigate to
$services.management_api.volumes
, and then add the following line of code:- ./license.key:/opt/graviteeio-management-api/license/license.key
-
-
Run
docker compose
using the following command:docker compose -f docker-compose-apim.yml up -d
-
To open the Console and the Developer portal, complete the following steps:
- To open the console, go to
http://localhost:8084
. - To open the Developer Portal, go to
http://localhost:8085.
{% hint style="info" %}
- The default username for the Console and the Developer Portal is admin.
- The default password for the Developer Portal is admin. {% endhint %}
{% hint style="success" %} Congratulations! Now that APIM is up and running, check out the Quickstart Guide for your next steps. {% endhint %}
- To open the console, go to
Federation is a new capability that was released with Gravitee 4.4.
Federation is disabled by default and must be explicitly activated for it to work.
To enable federation, follow the first guide below to enable federation with Docker Compose.
If in addition you are running multiple replicas of APIM for high availability, you'll also need to ensure that cluster mode is set up.
To enable federation, define the following environment variable and set its value to true
(default is false
):
GRAVITEE_INTEGRATION_ENABLED = true
For cases where APIM is running with high availability, you'll need to setup cluster mode.
The following parameters and values need to be added to the root of the gravitee.yaml configuration file:
GRAVITEE_CLUSTER_TYPE = hazelcast
GRAVITEE_CLUSTER_HAZELCAST_CONFIGPATH = ${gravitee.home}/config/hazelcast.xml
GRAVITEE_CACHE_TYPE = hazelcast
GRAVITEE_CACHE_HAZELCAST_CONFIGPATH = ${gravitee.home}/config/hazelcast.xml
In addition, you'll need to mount a volume with the hazelcast.xml configuration file. This is used to configure Hazelcast that will run as a library inside the APIM container.
An example hazelcast.xml configuration file will be included in the distribution, but you may need to change certain parts (those emphasized below):
<?xml version="1.0" encoding="UTF-8"?>
<hazelcast xmlns="http://www.hazelcast.com/schema/config"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://www.hazelcast.com/schema/config
http://www.hazelcast.com/schema/config/hazelcast-config-5.3.xsd">
<cluster-name>graviteeio-api-cluster</cluster-name>
<properties>
<property name="hazelcast.discovery.enabled">true</property>
<property name="hazelcast.max.wait.seconds.before.join">3</property>
<property name="hazelcast.member.list.publish.interval.seconds">5</property>
<property name="hazelcast.socket.client.bind.any">false</property>
<property name="hazelcast.logging.type">slf4j</property>
</properties>
<queue name="integration-cluster-command-*">
<backup-count>0</backup-count>
<async-backup-count>1</async-backup-count>
</queue>
<map name="integration-controller-primary-channel-candidate">
<backup-count>0</backup-count>
<async-backup-count>1</async-backup-count>
</map>
<cp-subsystem>
<cp-member-count>0</cp-member-count>
</cp-subsystem>
<network>
<!-- CUSTOMIZE THIS JOIN SECTION -->
<join>
<auto-detection/>
<multicast enabled="false"/>
<tcp-ip enabled="true">
<interface>127.0.0.1</interface>
</tcp-ip>
</join>
</network>
</hazelcast>
You will also need to add two new plugins to APIM that aren’t included by default:
- https://download.gravitee.io/plugins/node-cache/gravitee-node-cache-plugin-hazelcast/gravitee-node-cache-plugin-hazelcast-5.18.1.zip
- https://download.gravitee.io/plugins/node-cluster/gravitee-node-cluster-plugin-hazelcast/gravitee-node-cluster-plugin-hazelcast-5.18.1.zip
\