Skip to content

Latest commit

 

History

History
250 lines (183 loc) · 8.72 KB

File metadata and controls

250 lines (183 loc) · 8.72 KB

Custom Install Gravitee API Management with Docker Compose

When you install Gravitee API Management (APIM) with Docker Compose, you can install custom plugins and control the location of the persistent data.

Before you begin

  • 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.

Installing Gravitee APIM

  1. 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
  2. Download the docker-compose.yml file as docker-compose-apim.yml using the following command:

    curl -L https://bit.ly/docker-apim-4x -o docker-compose-apim.yml
  3. To ensure that the docker-compose-apim.yml uses the gravitee directory structure, follow the following sub-steps:

    1. In a text editor, open docker-compose-apim.yml

    2. Remove the following lines of code:

      {% code overflow="wrap" %}

      volumes:
        data-elasticsearch:
        data-mongo:

      {% endcode %}

    3. 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 %}

    4. 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 %}

    5. 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 %}

    6. Remove $services.management_api.links.

    7. 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 %}

    8. 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
    9. Add the following lines to $services.management_ui:

      volumes:
        - ./apim-management-ui/logs:/var/log/nginx
    10. Add the following lines to $services.portal_ui:

      volumes:
        - ./apim-portal-ui/logs:/var/log/nginx
  4. (Optional) If you are using the Enterprise Edition (EE) of Gravitee APIM, add your license key by following the following steps:

    1. Copy your license key to /gravitee/license.key.

    2. In a text editor, open the docker-compose-apim.yml file.

    3. Navigate to $services.gateway.volumes, and then add the following line of code:

      - ./license.key:/opt/graviteeio-gateway/license/license.key
    4. Navigate to $services.management_api.volumes, and then add the following line of code:

      - ./license.key:/opt/graviteeio-management-api/license/license.key
  5. Run docker composeusing the following command:

    docker compose -f docker-compose-apim.yml up -d
  6. 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 %}

Enable Federation

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.

Enable Federation with Docker Compose

To enable federation, define the following environment variable and set its value to true (default is false):

GRAVITEE_INTEGRATION_ENABLED = true

Set up cluster mode

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:

\