Aller au contenu

Installation de Canopsis avec Docker Compose

Cette procédure décrit l'installation de Canopsis en mono-instance Docker Compose.

Prérequis

Prérequis de version du noyau Linux

Lors de l'utilisation de Docker, Canopsis nécessite un noyau Linux 4.4 minimum sur votre système hôte.

Vérifiez votre version du noyau à l'aide de la commande suivante :

uname -r

Si la version affichée est inférieure à 4.4, vous devez soit utiliser une distribution plus à jour, ou bien mettre à jour votre noyau à l'aide d'ELRepo pour CentOS, par exemple.

Important

Une utilisation de Canopsis avec Docker Compose et un noyau inférieur à 4.4 ne sera ni supportée ni prise en charge.

Installation de Docker et Docker Compose

Vous devez tout d'abord installer Docker, version 19.03.5 minimum. Veuillez utiliser les dépôts officiels de Docker, et non pas ceux proposés par votre distribution.

Une fois Docker installé, vous devez ensuite installer Docker Compose.

Lancement de Canopsis avec Docker Compose

Les images Docker officielles de Canopsis sont hébergées sur Docker Hub : https://hub.docker.com/u/canopsis/ et seront prochainement migrées vers notre propre registre Docker.

Le dépôt Git de Canopsis contient des fichiers Docker Compose d'exemple :

git clone -b develop https://git.canopsis.net/canopsis/canopsis.git && cd canopsis/docker-compose

Attention

La variable CANOPSIS_IMAGE_TAG du fichier .env a pour valeur par défaut nightly, ce qui correspond à la version la plus récente des images disponibles sur Docker Hub. Notez que cela englobe également les versions intermédiaires destinées au développement et aux tests. Aussi, le tag nightly ne doit pas être utilisé pour un environnement de production.

Récupérez les dernières images disponibles :

docker-compose pull

Lancez ensuite la commande suivante, afin de démarrer un environnement Canopsis open-core complet :

docker-compose up -d

Vérification du bon fonctionnement

La vérification va passer par la commande docker-compose ps :

docker-compose ps

             Name                           Command               State                Ports
--------------------------------------------------------------------------------------------------------
docker-compose_action_1          /engine-action                   Up
docker-compose_axe_1             /engine-axe                      Up
docker-compose_che_1             /engine-che -d -publishQue ...   Up
docker-compose_fifo_1            /engine-fifo                     Up
docker-compose_heartbeat_1       /engine-heartbeat                Up
docker-compose_influxdb_1        /entrypoint.sh influxd           Up       0.0.0.0:4444->4444/udp,
                                                                           0.0.0.0:8083->8083/tcp,
                                                                           0.0.0.0:8086->8086/tcp
docker-compose_init_1            /bin/sh -c /${_BINARY_NAME}      Exit 0
docker-compose_mongodb_1         docker-entrypoint.sh --wir ...   Up       0.0.0.0:27027->27017/tcp
docker-compose_nginx_1           /bin/sh -c /entrypoint.sh        Up       0.0.0.0:80->80/tcp
docker-compose_pbehavior_1       /bin/sh -c /entrypoint.sh        Up       8082/tcp
docker-compose_provisioning_1    /bin/sh -c /entrypoint-prov.sh   Exit 0
docker-compose_rabbitmq_1        docker-entrypoint.sh rabbi ...   Up       15671/tcp,
                                                                           0.0.0.0:15672->15672/tcp,
                                                                           25672/tcp, 4369/tcp,
                                                                           5671/tcp,
                                                                           0.0.0.0:5672->5672/tcp
docker-compose_redis_1           docker-entrypoint.sh redis ...   Up       0.0.0.0:6379->6379/tcp
docker-compose_scheduler_1       /bin/sh -c /entrypoint.sh        Up       8082/tcp
docker-compose_task_importctx_1  /bin/sh -c /entrypoint.sh        Up       8082/tcp
docker-compose_watcher_1         /bin/sh -c /${_BINARY_NAME}      Up
docker-compose_webserver_1       /bin/sh -c /entrypoint.sh        Up       0.0.0.0:8082->8082/tcp

Les services doivent être en état Up ou Exit 0. En fonction des ressources de votre machine, il peut être nécessaire d'attendre quelques minutes avant que l'ensemble des moteurs puissent passer en état Up.

Vous pouvez alors procéder à votre première connexion à l'interface Canopsis.

Arrêt de l'environnement Docker Compose

docker-compose down

Stopping docker-compose_nginx_1          ... done
Stopping docker-compose_webserver_1      ... done
Stopping docker-compose_task_importctx_1 ... done
Stopping docker-compose_scheduler_1      ... done
Stopping docker-compose_pbehavior_1      ... done
Stopping docker-compose_mongodb_1        ... done
Stopping docker-compose_fifo_1           ... done
Stopping docker-compose_action_1         ... done
Stopping docker-compose_axe_1            ... done
Stopping docker-compose_redis_1          ... done
Stopping docker-compose_che_1            ... done
Stopping docker-compose_influxdb_1       ... done
Stopping docker-compose_heartbeat_1      ... done
Stopping docker-compose_rabbitmq_1       ... done
Stopping docker-compose_watcher_1        ... done
Removing docker-compose_nginx_1          ... done
Removing docker-compose_webserver_1      ... done
Removing docker-compose_provisioning_1   ... done
Removing docker-compose_task_importctx_1 ... done
Removing docker-compose_scheduler_1      ... done
Removing docker-compose_pbehavior_1      ... done
Removing docker-compose_init_1           ... done
Removing docker-compose_mongodb_1        ... done
Removing docker-compose_fifo_1           ... done
Removing docker-compose_action_1         ... done
Removing docker-compose_axe_1            ... done
Removing docker-compose_redis_1          ... done
Removing docker-compose_che_1            ... done
Removing docker-compose_influxdb_1       ... done
Removing docker-compose_heartbeat_1      ... done
Removing docker-compose_rabbitmq_1       ... done
Removing docker-compose_watcher_1        ... done
Removing network docker-compose_default

Rétention des logs

La mise en place d'une politique de rétention des logs nécessite la présence du logiciel logrotate.

Une fois que logrotate est installé sur votre machine, créer le fichier /etc/logrotate.d/docker-container suivant :

/var/lib/docker/containers/*/*.log {
  rotate 7
  daily
  compress
  minsize 100M
  notifempty
  missingok
  delaycompress
  copytruncate
}

Pour vérifier la bonne exécution de la configuration de logrotate pour Docker, vous pouvez lancer la commande :

logrotate -fv /etc/logrotate.d/docker-container

Dernière mise à jour: 2021-02-25