Installation de Canopsis avec Docker Compose¶
Cette procédure décrit l'installation de Canopsis avec Docker Compose.
Prérequis¶
Utilisation de Docker Compose¶
Docker Compose est actuellement l'orchestrateur Docker à utiliser pour Canopsis.
Important
Les conteneurs Docker produits pour Canopsis ne sont pas garantis d'être compatibles avec un autre orchestrateur que Docker Compose. La compatibilité avec d'autres outils tels que Kubernetes, Docker Swarm, Consul, OpenShift, etc. n'est ainsi pas assurée.
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
L'utilisation de Docker Compose avec un noyau inférieur à 4.4 n'est pas prise en charge.
Installation de Docker et Docker Compose¶
Vous devez tout d'abord installer Docker, version 20.10 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.
Attention
Dans certaines configurations, les versions les plus récentes de Docker Compose peuvent activer Compose v2 par défaut.
Compose v2 est une réécriture importante de Docker Compose mais elle est, à ce jour, en partie incomplète et instable par rapport à Compose v1. Canopsis ne prend donc pas en charge Compose v2 pour le moment.
Si la commande docker-compose version --short
vous renvoie un numéro de version supérieur ou égal à 2.0.0
, vous devez désactiver Compose v2 avec la commande docker-compose disable-v2
. Voyez la documentation de Compose V2 pour en savoir plus.
Lancement de Canopsis avec Docker Compose¶
Les images Docker officielles de Canopsis sont hébergées sur notre propre registre Docker, docker.canopsis.net
.
Le dépôt Git de Canopsis contient des fichiers Docker Compose d'exemple :
git clone -b develop https://git.canopsis.net/canopsis/canopsis-community.git && cd canopsis-community/community/docker-compose
Récupérez les dernières images disponibles :
docker-compose pull
Lancez ensuite la commande suivante, afin de démarrer un environnement Canopsis Community 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_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_service_1 /bin/sh -c /${_BINARY_NAME} Up
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_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_heartbeat_1 ... done
Stopping docker-compose_rabbitmq_1 ... done
Stopping docker-compose_service_1 ... done
Removing docker-compose_nginx_1 ... done
Removing docker-compose_webserver_1 ... done
Removing docker-compose_provisioning_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_heartbeat_1 ... done
Removing docker-compose_rabbitmq_1 ... done
Removing docker-compose_service_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