Consul - Installation
À des fins de démonstration, nous allons utiliser l'agent consul en mode développeur en utilisant le mode -dev. Juste pour la configuration de la machine locale, nous allons faire une configuration de consul de système unique.Please do not use this single node consul cluster in your production. Comme Hashicorp le mentionne déjà dans le scénario de cas d'un cluster consul à nœud unique,the data loss is inevitable.
Installation de Consul
Consul peut être installé via la page Téléchargements sur www.consul.io/downloads.html
Vous pouvez extraire le package binaire dans votre section Téléchargements de votre machine.
$ cd Downloads
$ chmod +x consul
$ sudo mv consul /usr/bin/
Commençons maintenant à utiliser consul en utilisant le -dev flag.
$ consul agent -dev -data-dir=/tmp/consul
La sortie serait comme indiqué dans la capture d'écran suivante.
Vous pouvez maintenant vérifier les membres de votre consul en utilisant la commande suivante.
$ consul members
La sortie serait comme indiqué dans la capture d'écran suivante.
Si vous souhaitez joindre d'autres nœuds à ce nœud -
$ consul join <Node 2> <Node 3>
Vous pouvez également exécuter la commande suivante sur les nœuds 2 et 3 -
$ consul join <Node 1>
Utilisation de la ligne de commande
La ligne de commande de consul se compose de plusieurs options différentes, certaines des plus couramment utilisées sont les suivantes -
agent - qui dirige un agent Consul.
configtest - pour valider un fichier de configuration.
event - pour démarrer un nouvel événement.
exec - pour exécuter une commande sur les nœuds Consul.
force-leave - forcer un membre du cluster à quitter le cluster.
info - il nous fournit les informations de débogage pour les opérateurs.
join - pour qu'un agent Consul rejoigne le cluster.
keygen - pour générer une nouvelle clé de chiffrement.
keyring - pour gérer les clés de chiffrement de la couche potins.
kv - pour interagir avec le magasin clé-valeur.
leave - quitter le cluster Consul et l'arrêter sans forcer.
lock - pour exécuter une commande pour maintenir un verrou.
maint - pour contrôler le nœud ou le mode maintenance du service.
members - il répertorie les membres d'un cluster Consul.
monitor - il diffuse les journaux d'un agent Consul.
operator - il nous fournit un ensemble d'outils pour les opérateurs Consul.
reload - il déclenche le rechargement des fichiers de configuration par l'agent.
rtt - il estime le temps d'aller-retour du réseau entre les nœuds.
snapshot - il enregistre, restaure et inspecte les instantanés de l'état du serveur Consul.
version - pour imprimer la version actuelle de Consul.
watch - Surveiller les changements du Consul.
Modèle de consul
Le consul-template nous fournit un démon qui interroge l'instance Consul et met à jour n'importe quel nombre de modèles spécifiés sur le système de fichiers. Le consul-template peut éventuellement exécuter des commandes arbitraires lorsque le processus de mise à jour est terminé. Cette option nous aide à configurer le cluster consul sans tout faire manuellement.
Le modèle de consul doit être formé à /tmp/<name-of-file>.conf.tmpfl. La langue dans laquelle le modèle est rédigé selonHashicorp Configuration Language (HCL).
Vous pouvez télécharger le modèle de consul à partir de cette page .
Essayez-le en utilisant la commande suivante -
$ ./consul-template -h
La sortie serait comme indiqué dans la capture d'écran suivante.
Si vous souhaitez déplacer ce binaire vers un espace plus visible, afin qu'il soit disponible pour l'utilisateur à chaque fois. Vous pouvez taper les commandes suivantes -
$ chmod +x consul-template
$ sudo mv consul-template /usr/share/bin/
À des fins de démonstration, nous allons utiliser un exemple de configuration de nginxà utiliser comme notre service. Vous pouvez essayer plus de démos surhttps://github.com/hashicorp/consul-template/tree/master/examples ou mieux écrivez votre propre modèle.
$ vim /tmp/nginx.conf.ctmpl
La sortie serait comme indiqué dans la capture d'écran suivante.
Le fichier de configuration peut ressembler à -
{{range services}} {{$name := .Name}} {{$service := service .Name}}
upstream {{$name}} {
zone upstream-{{$name}} 64k;
{{range $service}}server {{.Address}}:{{.Port}} max_fails = 3 fail_timeout = 60
weight = 1;
{{else}}server 127.0.0.1:65535; # force a 502{{end}}
} {{end}}
server {
listen 80 default_server;
location / {
root /usr/share/nginx/html/;
index index.html;
}
location /stub_status {
stub_status;
}
{{range services}} {{$name := .Name}}
location /{{$name}} {
proxy_pass http://{{$name}};
}
{{end}}
}
Maintenant, en utilisant le fichier binaire du modèle consul, veuillez exécuter les commandes suivantes -
$ consul-template \
-template = "/tmp/nginx.conf.ctmpl:/etc/nginx/conf.d/default.conf"
Avec la commande précédente, le processus a démarré. Vous pouvez ultérieurement ouvrir un autre terminal et afficher le fichier nginx.conf en cours de rendu complet à l'aide de la commande suivante.
$ cat /etc/nginx/conf.d/default.conf
La sortie serait comme indiqué dans la capture d'écran suivante.