SaltStack - Guide rapide

Dans ce chapitre, nous allons apprendre les bases de SaltStack. Les capacités d'exécution à distance de SaltStack permettent aux administrateurs d'exécuter des commandes sur diverses machines en parallèle avec un système de ciblage flexible. La gestion de la configuration de Salt établit un modèle maître-serviteur pour mettre rapidement, très facilement, de manière flexible et sécurisée les composants de l'infrastructure en conformité avec une politique donnée.

Qu'est-ce que SaltStack?

Salt est un framework d'automatisation très puissant. L'architecture Salt est basée sur l'idée d'exécuter des commandes à distance. Tout le réseau est conçu autour d'un aspect de l'exécution à distance. Cela pourrait être aussi simple que de demander à unRemote Web Serverpour afficher une page Web statique, ou aussi complexe que l'utilisation d'une session shell pour émettre de manière interactive des commandes sur un serveur distant. Salt est un exemple de l'un des types d'exécution à distance les plus complexes.

Salt est conçu pour permettre aux utilisateurs de cibler et d'émettre des commandes de manière explicite vers plusieurs machines directement. Salt est basé sur l'idée d'un Master, qui contrôle un ou plusieursMinions. Les commandes sont normalement émises par le maître à un groupe cible de serviteurs, qui exécutent ensuite les tâches spécifiées dans les commandes, puis renvoient les données résultantes au maître. Les communications entre un maître et des serviteurs se produisent sur leZeroMQ message bus.

Les modules SaltStack communiquent avec les systèmes d'exploitation minion pris en charge. leSalt Masters'exécute sur Linux par défaut, mais n'importe quel système d'exploitation peut être un serviteur, et actuellement les variantes Windows, VMware vSphere et BSD Unix sont bien prises en charge. Le Salt Master et les serviteurs utilisent des clés pour communiquer. Lorsqu'un serviteur se connecte à un maître pour la première fois, il stocke automatiquement les clés sur le maître. SaltStack propose égalementSalt SSH, qui fournit une gestion des systèmes «sans agent».

Besoin de SaltStack

SaltStack est conçu pour la vitesse et l'échelle. C'est pourquoi il permet de gérer de grandes infrastructures avec des dizaines de milliers de serveurs chez LinkedIn, WikiMedia et Google.

Imaginez que vous ayez plusieurs serveurs et que vous souhaitiez faire des choses sur ces serveurs. Vous devrez vous connecter à chacun d'eux et faire ces choses une à la fois sur chacun d'eux, puis vous voudrez peut-être faire des choses compliquées comme installer un logiciel, puis configurer ce logiciel en fonction de certains critères spécifiques.

Supposons que vous ayez dix, voire 100 serveurs. Imaginez que vous vous connectiez un par un à chaque serveur individuellement, émettant les mêmes commandes sur ces 100 machines, puis éditant les fichiers de configuration sur les 100 machines devient une tâche très fastidieuse. Pour surmonter ces problèmes, vous aimeriez mettre à jour tous vos serveurs à la fois, simplement en tapant une seule commande. SaltStack vous fournit exactement la solution à tous ces problèmes.

Caractéristiques de SaltStack

SaltStack est un logiciel de gestion de configuration open source et un moteur d'exécution à distance. Salt est un outil de ligne de commande. Bien qu'elle soit écrite en Python, la gestion de la configuration de SaltStack est indépendante du langage et simple. Salt Platform utilise le modèle push pour exécuter des commandes via le protocole SSH. Le système de configuration par défaut estYAML et Jinja templates. Le sel est principalement en concurrence avecPuppet, Chef et Ansible.

Salt offre de nombreuses fonctionnalités par rapport à d'autres outils concurrents. Certaines de ces caractéristiques importantes sont énumérées ci-dessous.

  • Fault tolerance- Les minions Salt peuvent se connecter à plusieurs maîtres à la fois en configurant le paramètre de configuration du maître sous la forme d'une liste YAML de tous les maîtres disponibles. Tout maître peut diriger des commandes vers l'infrastructure Salt.

  • Flexible- L'ensemble de l'approche de gestion de Salt est très flexible. Il peut être implémenté pour suivre les modèles de gestion de systèmes les plus courants tels que l'agent et le serveur, l'agent uniquement, le serveur uniquement ou tout ce qui précède dans le même environnement.

  • Scalable Configuration Management - SaltStack est conçu pour gérer dix mille serviteurs par maître.

  • Parallel Execution model - Salt peut activer des commandes pour exécuter des systèmes distants de manière parallèle.

  • Python API - Salt fournit une interface de programmation simple et il a été conçu pour être modulaire et facilement extensible, pour le rendre facile à mouler à diverses applications.

  • Easy to Setup - Salt est facile à configurer et fournit une architecture d'exécution à distance unique capable de gérer les diverses exigences de n'importe quel nombre de serveurs.

  • Language Agnostic - Les fichiers de configuration d'état Salt, le moteur de création de modèles ou le type de fichier prend en charge tout type de langage.

Avantages de SaltStack

Étant simple et riche en fonctionnalités, Salt offre de nombreux avantages et ils peuvent être résumés comme suit -

  • Robust - Salt est un cadre de gestion de configuration puissant et robuste et fonctionne autour de dizaines de milliers de systèmes.

  • Authentication - Salt gère des paires de clés SSH simples pour l'authentification.

  • Secure - Salt gère les données sécurisées à l'aide d'un protocole crypté.

  • Fast - Salt est un bus de communication très rapide et léger pour fournir la base d'un moteur d'exécution à distance.

  • Virtual Machine Automation - La capacité Salt Virt Cloud Controller est utilisée pour l'automatisation.

  • Infrastructure as data, not code - Salt fournit un déploiement simple, une gestion de la configuration basée sur un modèle et un cadre d'exécution de commande.

Introduction à ZeroMQ

Salt est basé sur le ZeroMQbibliothèque et c'est une bibliothèque de mise en réseau intégrable. Il est léger et une bibliothèque de messagerie rapide. La mise en œuvre de base est enC/C++ et implémentations natives pour plusieurs langues, y compris Java et .Net est disponible.

ZeroMQ est un traitement de messages homologue sans courtier. ZeroMQ vous permet de concevoir facilement un système de communication complexe.

ZeroMQ est livré avec les cinq modèles de base suivants -

  • Synchronous Request/Response - Utilisé pour envoyer une demande et recevoir des réponses ultérieures pour chacune d'entre elles.

  • Asynchronous Request/Response- Le demandeur lance la conversation en envoyant un message de demande et attend un message de réponse. Le fournisseur attend les messages de demande entrants et répond avec les messages de réponse.

  • Publish/Subscribe - Utilisé pour distribuer des données d'un seul processus (par exemple éditeur) à plusieurs destinataires (par exemple abonnés).

  • Push/Pull - Utilisé pour distribuer des données aux nœuds connectés.

  • Exclusive Pair - Utilisé pour connecter deux pairs ensemble, formant une paire.

ZeroMQ est un outil de mise en réseau très flexible pour l'échange de messages entre les clusters, le cloud et d'autres environnements multi-systèmes. ZeroMQ est ledefault transport library présenté dans SaltStack.

L'architecture de SaltStack est conçue pour fonctionner avec n'importe quel nombre de serveurs, des systèmes de réseau local à d'autres déploiements dans différents centres de données. L'architecture est un modèle serveur / client simple avec les fonctionnalités nécessaires intégrées dans un seul ensemble de démons.

Jetez un œil à l'illustration suivante. Il montre les différents composants de l'architecture SaltStack.

  • SaltMaster- SaltMaster est le démon maître. Un SaltMaster est utilisé pour envoyer des commandes et des configurations aux esclaves Salt. Un seul maître peut gérer plusieurs maîtres.

  • SaltMinions- SaltMinion est le démon esclave. Un minion Salt reçoit les commandes et la configuration du SaltMaster.

  • Execution- Modules et commandes Adhoc exécutés depuis la ligne de commande contre un ou plusieurs serviteurs. Il effectue une surveillance en temps réel.

  • Formulas- Les formules sont pré-écrites Salt States. Ils sont aussi ouverts que Salt States eux-mêmes et peuvent être utilisés pour des tâches telles que l'installation d'un package, la configuration et le démarrage d'un service, la configuration d'utilisateurs ou d'autorisations et de nombreuses autres tâches courantes.

  • Grains- Grains est une interface qui fournit des informations spécifiques à un serviteur. Les informations disponibles via l'interface grains sont statiques. Les grains sont chargés lorsque le serviteur de sel démarre. Cela signifie que les informations contenues dans les grains sont inchangées. Par conséquent, les informations sur les grains peuvent concerner le noyau en cours d'exécution ou le système d'exploitation. Il est insensible à la casse.

  • Pillar- Un pilier est une interface qui génère et stocke des données hautement sensibles spécifiques à un serviteur particulier, telles que des clés cryptographiques et des mots de passe. Il stocke les données dans une paire clé / valeur et les données sont gérées de la même manière que l'arbre d'état de sel.

  • Top File - Fait correspondre les états de Salt et les données des piliers aux sbires de Salt.

  • Runners - C'est un module situé à l'intérieur du SaltMaster et effectue des tâches telles que l'état du travail, l'état de la connexion, la lecture de données à partir d'API externes, l'interrogation des sbires de sel connectés et plus encore.

  • Returners - Renvoie les données des sbires de Salt vers un autre système.

  • Reactor - Il est responsable du déclenchement des réactions lorsque des événements se produisent dans votre environnement SaltStack.

  • SaltCloud - Salt Cloud fournit une interface puissante pour interagir avec les hôtes cloud.

  • SaltSSH - Exécutez les commandes Salt via SSH sur les systèmes sans utiliser Salt minion.

Dans le chapitre suivant, nous apprendrons en détail les différents concurrents de SaltStack et leurs fonctionnalités.

Salt, Puppet, Chef et Ansible sont les principaux outils de gestion de configuration et d'orchestration, chacun empruntant un chemin différent vers l'automatisation des serveurs. Ils ont été conçus pour faciliter la configuration et la maintenance de dizaines, de centaines, voire de milliers de serveurs.

Comprenons comment SaltStack est principalement en concurrence avec Puppet, Chef et Ansible.

Plateformes et support

Voici une liste de toutes les plates-formes qui prennent en charge SaltStack et ses concurrents.

  • SaltStack - Le logiciel SaltStack fonctionne sur et gère de nombreuses versions de Linux, Windows, Mac OS X et UNIX.

  • Puppet - Red Hat Enterprise Linux, CentOS, Oracle Linux, Scientific Linux, SUSE Linux Enterprise Server et Ubuntu.

  • Chef - Chef est pris en charge sur plusieurs plates-formes telles que AIX, RHEL / CentOS, FreeBSD, OS X, Solaris, Microsoft Windows et Ubuntu.

  • Ansible - Distribution Fedora de Linux, CentOS et Scientific Linux via des packages supplémentaires pour Enterprise Linux (EPEL) ainsi que pour d'autres systèmes d'exploitation.

Langue d'origine

  • SaltStack - Python

  • Puppet - Rubis

  • Chef - Ruby et sa CLI utilisent le DSL basé sur Ruby

  • Ansible - Python

Langue prise en charge

  • SaltStack - Toute langue

  • Puppet - Rubis

  • Chef - Ruby et sa CLI utilisent le DSL basé sur Ruby

  • Ansible - Toute langue

UI Web

  • SaltStack - L'interface utilisateur Web offre des vues des tâches en cours d'exécution, de l'état des serviteurs et des journaux d'événements.

  • Puppet - L'interface utilisateur Web gère les rapports, l'inventaire et la gestion des nœuds en temps réel.

  • Chef - L'interface utilisateur Web vous permet de rechercher et d'inventorier les nœuds, d'afficher l'activité des nœuds et d'attribuer des livres de recettes, des rôles et des nœuds.

  • Ansible - L'interface utilisateur Web vous permet de configurer les utilisateurs, les équipes et les inventaires et d'appliquer des playbooks aux inventaires.

Outils de gestion

  • SaltStack - SaltStack Enterprise se positionne comme le principal outil de gestion de l'orchestration des opérations cloud et IT, ainsi que DevOps.

  • Puppet- Puppet est disponible en deux versions, Puppet Enterprise et Open Source Puppet. En plus de fournir les fonctionnalités d'Open Source Puppet, Puppet Enterprise fournit également des outils d'interface graphique, d'API et de ligne de commande pour la gestion des nœuds.

  • Chef - CFEngine est l'outil de gestion de configuration.

  • Ansible - Ansible 1.3 est le principal outil de gestion.

Performance

  • SaltStack- Salt est conçu pour des performances et une évolutivité élevées. Le système de communication de Salt établit un canal de données persistant entre le maître Salt et les sbires à l'aide de ZeroMQ.

  • Puppet - Sécurisé et performant et aucun agent requis.

  • Chef- La lutte la plus apparente pour Chef Server est la recherche; La recherche est lente et n'est pas demandée simultanément aux clients.

  • Ansible - Sécurisé, performant et sans agent requis.

Prix ​​et valeur

  • SaltStack- Version open source gratuite. SaltStack Enterprise coûte 150 $ par machine et par an.

  • Puppet- Version open source gratuite. Puppet Enterprise coûte 100 $ par machine et par an.

  • Chef- Version open source gratuite; Enterprise Chef gratuit pour 5 machines,$120 per month for 20 machines, $300 par mois pour 50 machines.

  • Ansible- Version open source gratuite; Ansible gratuit pour 10 machines, puis$100 or $250 par machine par an selon le support dont vous avez besoin.

Usage

  • SaltStack- SaltStack est utilisé par Cisco et Rackspace. Il peut s'intégrer à n'importe quelle plateforme basée sur le cloud.

  • Puppet - Puppet est utilisé par Zynga, Twitter, la Bourse de New York, PayPal, Disney, Google et ainsi de suite.

  • Chef - Chef peut s'intégrer aux plates-formes cloud telles que Internap, Amazon EC2, Google Cloud Platform, OpenStack, Microsoft Azure et Rackspace.

  • Ansible - Ansible peut se déployer dans des environnements de virtualisation, des environnements cloud, notamment Amazon Web Services, Cloud Stack, DigitalOcean et Google Cloud Platform, etc.

Avant de passer à l'installation, vous devez avoir les exigences suivantes -

  • Un serveur Linux (dernier serveur Ubuntu).

  • sudo ou root access à ce serveur.

Installez toutes les mises à jour à l'aide de la commande suivante -

sudo apt-get update

Installez SaltMaster

Installez le SaltMaster à partir du référentiel avec la commande apt-get suivante.

sudo apt-get install salt-master

Installer Salt Minion

Installez le minion Salt à partir du référentiel avec la commande apt-get suivante.

sudo apt-get install salt-minion

Installez Salt Syndic

Installez Salt syndic à partir du référentiel avec la commande apt-get suivante.

sudo apt-get install salt-syndic

Configuration principale

La configuration Salt est très simple. La configuration par défaut du maître fonctionnera pour la plupart des installations. Les fichiers de configuration sont installés dans le répertoire '/ etc / salt' et sont nommés d'après leurs composants respectifs, tels que - / etc / salt / master et / etc / salt / minion.

#interface: 0.0.0.0
interface: <local ip address>

Après avoir mis à jour le fichier de configuration, redémarrez Salt Master à l'aide de la commande suivante.

sudo service salt-master restart

Configuration des sbires

La configuration d'un Salt Minion est très simple. Par défaut, un Salt Minion essaiera de se connecter au nom DNS «salt»; si le Minion est capable de résoudre correctement ce nom, aucune configuration n'est requise. Redéfinissez la directive «master» dans le fichier de configuration des minions, qui est généralement/etc/salt/minion, comme indiqué dans le code ci-dessous -

#master: salt
master: <local ip address>

Après avoir mis à jour le fichier de configuration, redémarrez le minion Salt en utilisant la commande ci-dessous.

sudo service salt-minion restart

Gestion des clés

Utilisations du sel AES Encryptionpour toutes les communications entre le Maître et le Minion. La communication entre Maître et Minion est authentifiée par des clés de confiance et acceptées.

salt-key -L

Il produira ce qui suit output -

Accepted Keys:
Denied Keys:
Unaccepted Keys:
<local system name>
Rejected Keys:

Acceptez toutes les clés en exécutant la commande ci-dessous.

sudo salt-key -A

Il produira ce qui suit output -

The following keys are going to be accepted:
Unaccepted Keys:
<local system name>
Proceed? [n/Y] y
Key for minion bala-Inspiron-N4010 accepted.

Maintenant, émettez à nouveau le salt key listing commander,

salt-key -L

Il produira ce qui suit output -

Accepted Keys:
<local system name>
Denied Keys:
Unaccepted Keys:
Rejected Keys:

Envoi de commandes

La communication entre le Maître et un Minion doit être vérifiée en exécutant la commande test.ping.

sudo salt '*' test.ping

Il produira ce qui suit output -

<local system name>
   True

Ici, «*» fait référence à tous les serviteurs. Depuis, nous n'avons qu'un seul minion - test.ping, il exécute leping et retourne si le ping a réussi ou non.

Dans ce chapitre, nous allons créer un environnement SaltStack simple, un maître de sel et deux minions de sel. Cet environnement nous aidera à apprendre le concept du sel dans les prochains chapitres.

Adhérons aux étapes suivantes pour créer l'environnement SaltStack.

Installez l'environnement VirtualBox

VirtualBox est une application de virtualisation multiplateforme. VirtualBox vous permet d'exécuter plus d'un système d'exploitation à la fois. VirtualBox fonctionne sous Windows, Linux, Macintosh et Solaris. Il héberge et prend en charge un grand nombre deGuest Operating Systems.

Vous pouvez télécharger et installer VirtualBox en visitant le lien suivant - https://www.virtualbox.org/wiki/Downloads

Nous allons créer trois machines virtuelles et les exécuter à l'aide de VirtualBox.

Installez Vagrant

Vagrant fournit des environnements de travail faciles à configurer, reproductibles et portables.

Vous pouvez télécharger et installer le Vagrant en visitant le lien suivant - https://www.vagrantup.com

Une fois l'installation réussie de Vagrant, vous devez le configurer. Créez un seul fichier nommé commeVagrantfile dans un dossier et décrivez le type de machine et ses propriétés.

Run Vagrant - Pour exécuter le Vagrant, exécutez la commande suivante -

vagrant up

Après avoir exécuté vagrant up, Vagrant crée et démarre ces machines, qui sont définies dans le Vagrantfileen utilisant la VirtualBox en arrière-plan. Ces machines fonctionneront jusqu'à ce que vous les fermiez.

Stop Vagrant - Pour arrêter toutes les machines en cours d'exécution dans VirtualBox, tapez la commande suivante -

vagrant halt

Téléchargez l'environnement de démonstration

SaltStack fournit un environnement de démonstration simple comme configuration Vagrant et il est hébergé dans le github. Laissez-nous télécharger l'installation en utilisant la commande suivante -

cd /cd/to/path

git clone https://github.com/UtahDave/salt-vagrant-demo

Environnement de démarrage

Maintenant, démarrez l'environnement de démonstration en utilisant la commande suivante -

cd /cd/to/path/salt-vagrant-demo
vagrant up

Après cette commande, vous verrez la réponse suivante -

result

Maintenant, trois serveurs sont en cours d'exécution, un avec le salt master configuré et deux avec le salt minion configuré.

Exécuter le maître du sel

Connectez-vous au Salt Master à l'aide de la commande suivante -

vagrant ssh master

Maintenant, passez à l'utilisateur root en utilisant la commande ci-dessous -

sudo su

Nous nous sommes maintenant connectés avec succès au Salt Master.

Passons maintenant en revue certaines des commandes de base de SaltStack.

Liste toutes les clés

La commande suivante consiste à vérifier les connexions de Salt minion et à voir si la connexion est acceptée, rejetée ou en attente.

salt-key —list-all

Il produira ce qui suit output -

Accepted Keys:
minion1
minion2
Denied Keys:

Unaccepted Keys:
Rejected Keys:

Vérifier Salt Minions

Maintenant, nous avons accepté toutes les clés, vous pouvez envoyer une commande de Salt Master pour vérifier si les sbires de Salt écoutent ou non,

salt '*' test.ping

Il produira ce qui suit output -

minion1:
   True
minion2:
   True

À partir du résultat ci-dessus, répertoriez les sbires 1 et 2, ce qui signifie que les sbires écoutent correctement, sinon les sbires pourraient désormais répondre correctement.

Un système de contrôle d'accès fournit des options permettant à un utilisateur d'un groupe d'exécuter une tâche avec des autorisations. Un système de contrôle d'accès Salt est utilisé pour configurer l'accès aux interfaces de contrôle non administratives. Vous pouvez appliquer ce processus à tous les systèmes. Ce contrôle aide les utilisateurs non administratifs à exécuter les commandes Salt.

Les interfaces Salt sont des trois types suivants -

  • Système ACL de l'éditeur
  • Système d'authentification externe
  • Système de pairs

Laissez-nous comprendre passer par chacune de ces interfaces en détail.

Système ACL de l'éditeur

Un système Publisher ACL permet d'accéder aux utilisateurs autres que root pour exécuter des commandes Salt sur les serviteurs du maître. Le système ACL de l'éditeur est configuré dans le fichier de configuration principal via lepublisher_acloption de configuration. Il est défini comme suit -

publisher_acl:
   user1:
      - .*

   user2:
      - web*:
         - test.*
         - pkg.*

Ici,

  • user1 est autorisé à exécuter quoi que ce soit.

  • user2 est autorisé à utiliser test et pkg, mais uniquement sur les sbires «web *».

Système d'authentification externe

le external auth system est utilisé pour fournir un accès pour exécuter des commandes de sel sur des sbires spécifiques via un système d'autorisation externe comme PAM, LDAP, etc. Ce fichier de configuration est défini dans le fichier maître comme décrit ci-dessous.

external_auth:
   pam:
      user1:
         - 'web*':
            - test.*
            - network.*
      user2:
         - .*

Ici,

  • user1 est autorisé à exécuter des fonctions dans test et network modules sur les serviteurs qui correspondent au web* cible.

  • user2 est autorisé à exécuter toutes les fonctions.

Activer le système d'authentification externe dans la commande

Le serveur Salt fournit une option «–a» pour activer l'authentification externe.

salt -a pam web\* test.ping

Ici le -a pamL'option est utilisée pour activer l'authentification externe PAM. Salt Server demandera les détails d'authentification chaque fois que nous exécutons la commande. Pour empêcher Salt Server de demander les détails d'authentification pour la première fois uniquement, nous pouvons utiliser l'option T. Ce-T option met en cache les détails d'authentification pour les 12 prochaines heures (paramètre par défaut) et les utilise pour authentifier les utilisateurs.

salt -T -a pam web\* test.ping

Système de pairs

Les sbires de Salt peuvent passer des commandes en utilisant l'interface homologue. L'interface homologue est configurée via le fichier de configuration principal pour permettre aux serviteurs d'envoyer des commandes à partir du maître en utilisant lepeer section de configuration ou pour permettre aux sbires d'exécuter des coureurs depuis le maître en utilisant le peer_run configuration.

Comprenons ces deux configurations en détail.

Configuration homologue

La configuration simple à définir dans le fichier maître est la suivante -

peer:
   .*:
      - .*

Ici, il permet la communication pour tous les sbires, mais il n'est recommandé que pour les environnements très sécurisés.

Pour attribuer des serviteurs à des ID spécifiques, la configuration doit être définie comme indiqué ci-dessous: pair -

.*domain.com:
   - test.*

Configuration peer_run

Cette configuration permet aux minions d'exécuter des coureurs depuis le maître en utilisant l'option peer_run sur le fichier maître. L'exemple suivant est d'autoriser l'accès à tous les serviteurs et à tous les coureurs.

peer_run:
   .*:
      - .*

Pour affecter des serviteurs à un ID spécifique, la configuration doit être définie comme indiqué ci-dessous -

peer_run:
   .*domain.com:
      - test.*

Comment exécuter des commandes

Éxécuter test.ping sur tous les serviteurs, utilisez le salt-call commande avec la publish.publish module.

salt-call publish.publish \* test.ping

Éxécuter runner, utilisez la commande salt-call avec le publish.runner module.

salt-call publish.runner manage.up

Salt a la capacité de communiquer à haut débit avec un grand nombre de systèmes. Cette approche aide Salt à créer un système multitâche puissant. Salt peut exécuter des tâches sur plus d'un système. Salt utilise donc une technique de gestion des tâches pour gérer chaque tâche exécutée sur tous les systèmes. Ce chapitre explique en détail la gestion des tâches.

Qu'est-ce qu'un ID de poste?

Salt a un répertoire de cache, cachedir. À l'intérieur, un répertoire que les sbires maintiennent est appeléprocannuaire. Il se trouve dans le répertoire suivant / var / cache / salt / proc.

Le répertoire proc est utilisé pour maintenir tous les fichiers. Lorsque ces fichiers sont exécutés, ils sont attribués avec un ID de travail unique. Cet identifiant de tâche permet d'identifier les tâches en cours d'exécution sur le serviteur et permet de rechercher les tâches.

Module SALTUTIL

Salt introduit un nouveau module appelé processus de gestion des travaux Saltutil. Ce module contient différentes fonctions pour gérer les jobs. Ces fonctions sont utilisées pour gérer les tâches au niveau des serviteurs. Les fonctions sont décrites brièvement comme suit -

  • running - Renvoie toutes les données des travaux en cours d'exécution qui se trouvent dans le répertoire proc.

  • find_job - Renvoie des données spécifiques sur un certain travail en fonction de l'ID du travail.

  • signal_job - Permet à un identifiant de travail donné (jid) de recevoir un signal.

  • term_job - Envoie un signal de fin pour le travail spécifié.

  • kill_job - Envoie un signal d'arrêt pour le travail spécifié.

Job Runner

Le Job Runner contient des fonctions pour rendre la visualisation des données plus facile et plus propre. Il a différentes fonctions. Examinons chacune de ces fonctions en détail.

Fonction ACTIVE

La fonction Actif est utilisée pour identifier les travaux en cours et vérifier quels systèmes ont terminé un travail et quels systèmes sont encore en attente. Il est exécuté à l'aide de la commande suivante,

salt-run jobs.active

Fonction LOOKUP_JID

Le runner lookup_jid affichera les données du travail recherché en cours. Ces jobs sont configurés via lekeep_jobsoption dans la configuration principale. Il est exécuté à l'aide de la commande suivante.

salt-run jobs.lookup_jid <job id number>

Fonction LIST_JOBS

La fonction List_jobs est utilisée pour lister les données de travaux pour les travaux. Il est exprimé par la commande suivante -

salt-run jobs.list_jobs

Planification des travaux

Le système de planification expose l'exécution de toute fonction d'exécution sur les serviteurs ou sur tout coureur sur le maître.

Il est effectué par les méthodes suivantes -

  • Schedule - L'option de planification dans le maître ou le serviteur config des dossiers.

  • Minion pillar data - Il actualise les données du pilier minion à l'aide de la commande saltutil.refresh_pillar.

  • L'état de planification ou le module de planification.

Les états de sel sont exécutés sur le serviteur. Vous pouvez transmettre les arguments de position et fournir unYAML dict des arguments nommés dans le config file comme indiqué ci-dessous.

schedule:
   job1:
      function: saltstate.sls
      seconds: 3600
      args:
         - httpd
      kwargs:
         test: True

Ici, job1 exécutera la fonction saltstate.sls avec les arguments spécifiés, httpdpour chaque heure. letest: True est l'argument supplémentaire pour le httpd commande définie dans saltstate.sls.

Le serveur de fichiers Salt est un serveur ZeroMQ sans état. Il est intégré au maître du sel. Un serveur de fichiers Salt est utilisé pour distribuer les fichiers du maître aux serviteurs. Il contient différents modules. Comprenons le serveur de fichiers salt, sa configuration, les modules liés au serveur de fichiers salt, comment accéder au serveur de fichiers salt en python, etc., dans ce chapitre.

Backend du serveur de fichiers

Le backend du serveur de fichiers permet au serveur de fichiers Salt d'agir comme une interface transparente avec un autre serveur de fichiers comme un système de fichiers local, un système de contrôle de version Git, etc.

Un backend de serveur de fichiers Git peut être activé en utilisant la configuration suivante dans le fichier maître.

fileserver_backend:
   - git

Pour activer plusieurs systèmes de fichiers backend, nous pouvons utiliser la configuration suivante.

fileserver_backend:
   - roots
   - git

Nous pouvons également spécifier l'option supplémentaire pour un serveur backend différent en utilisant la section spécifique du serveur backend correspondant.

Système de fichiers local

Pour utiliser ce système, nous devons utiliser le code suivant.

file_roots:
   base:
      - /srv/salt/prod

Système de fichiers Git

Pour utiliser ce système, nous devons utiliser le code suivant.

gitfs_remotes:
   - https://github.com/sample/sample1.git

Demande de fichiers

Salt a la possibilité de demander des fichiers pour des environnements spécifiques.

salt://path/to/file?saltenv = base

Ici, l'environnement est défini à l'aide de l'option racines.

Configuration du serveur de fichiers

Les fichiers Salt peuvent être alloués dans de nombreux répertoires racine et accessibles en spécifiant à la fois le chemin du fichier et l'environnement à rechercher. Les environnements individuels peuvent s'étendre sur plusieurs racines de répertoires.

Environnement

L'environnement par défaut est base. Cet environnement est défini et est utilisé pour télécharger des fichiers lorsqu'aucun autre environnement n'est spécifié.

file_roots:
   base:
      - /srv/salt/base

Vous pouvez également utiliser plusieurs environnements comme indiqué dans le code ci-dessous.

file_roots:
   base:
      - /srv/salt/base
   dev:
      - /srv/salt/dev
      - /srv/salt/base

Module CP

Le module CP est le module principal pour manipuler le Salt file server. lesalt-cp peut également être utilisée pour distribuer des fichiers présentés par le serveur de fichiers Salt.

GET_FILE

le cp.get_fileLa fonction peut être utilisée sur le minion pour télécharger un fichier à partir du maître. Il est défini comme indiqué dans le bloc de code suivant.

salt '*' cp.get_file salt://vimrc /etc/vimrc

La commande ci-dessus demande à tous les sbires de Salt de télécharger le vimrc fichier et copiez-le dans /etc/vimrc.

Activer le modèle

Vous pouvez activer l'option de modèle dans get_file comme suit -

salt '*' cp.get_file "salt://vimrc" /etc/vimrc template = jinja

Appliquer la compression

Pour utiliser la compression, utilisez le gzipargument nommé. Les valeurs valides sont des entiers de 1 à 9, où 1 est la compression minimale et 9 est la valeur maximale.

La commande est définie comme suit -

salt '*' cp.get_file salt://vimrc /etc/vimrc gzip = 5

GET_DIR

le cp.get_dirLa fonction peut être utilisée sur le minion pour télécharger un répertoire entier à partir du maître. Il est défini dans le bloc de code suivant.

salt '*' cp.get_dir salt://etc/mysql /etc

le cp.get_dirprend en charge le rendu de modèle et les arguments de compression gzip. Si vous le souhaitez, vous pouvez également attribuer.

Module FILECLIENT

Salt fournit un module python qui permet d'accéder au serveur de fichiers salt. lesalt/fileclient.py Le module est utilisé pour établir la communication entre le serviteur et le maître.

L'exemple de code pour obtenir des fichiers est le suivant -

import salt.minion
import salt.fileclient

def get_file(path, dest, saltenv = ‘base'):
   client = salt.fileclient.get_file_client(__opts__)
   return client.get_file(path, dest, true, saltenv)

Ici,

  • opts est disponible lorsque le module est exécuté dans l'environnement salt. Sinon, nous devrions fournir le chemin de configuration -/etc/salt/minion.

  • path fait référence au chemin du fichier source dans le serveur de fichiers salt.

  • dest fait référence au chemin de destination du fichier.

  • saltenv fait référence à l'environnement

Dans le chapitre suivant, nous comprendrons comment utiliser Git en tant que serveur de fichiers.

Gitest un système de contrôle de version distribué open source. Il peut être utilisé pour garder une trace des modifications dans tous les fichiers. Salt envoie des fichiers à partir de référentiels Git à l'aide du serveur de fichiers Git. Vous pouvez configurer Git sur lefileserver_backend list et si vous devez configurer un ou plusieurs référentiels, vous pouvez le faire en utilisant le gitfs_remotes option.

Ce chapitre explique comment installer et configurer le serveur de fichiers Git. Avant de passer à l'installation, vous devez avoir les prérequis suivants.

Conditions préalables de Salt Server pour l'utilisation de Git

La configuration minimale requise pour que le serveur salt utilise Git comme serveur de fichiers est la suivante:

  • pygit2
  • Dulwich

Pygit2 et Dulwich sont configurés à l'aide du gitfs_providerparamètre dans le fichier de configuration principal. Sigitfs_provider n'est pas configuré dans le fichier maître, Salt préférera pygit2, si la version appropriée est disponible, suivi de GitPython et Dulwich.

Installez pygit2

Les commandes suivantes sont utilisées pour installer pygit2 dans les systèmes basés sur Fedora et Ubuntu -

  • Fedora-based system

yum install python-pygit2
  • Ubuntu-based system

apt-get install python-pygit2

Ici, la version minimale prise en charge de pygit2 est 0.20.3.

Installez GitPYTHON

GitPython peut être facilement installé sur le maître en utilisant le yum / apt command comme indiqué ci-dessous.

  • Fedora-based system

yum install GitPython
  • Ubuntu-based system

apt-get install python-git

Installez DULWICH

Dulwich peut être facilement installé sur le maître à l'aide de la commande yum.

  • Fedora-based system

yum install python-dulwich
  • Ubuntu-based system

apt-get install python-dulwich

Maintenant, nous avons installé toutes les dépendances pour le serveur de fichiers Git. Configurons maintenant ce serveur de fichiers Git en utilisant lefileserver_backend section dans le master config fichier.

Configuration du backend

Pour utiliser le serveur de fichiers Git, vous devez ajouter Git dans la liste fileserver_backend du fichier de configuration principal. Il est décrit comme suit -

fileserver_backend:
   - git

Comprenons plus en détail comment configurer le serveur de fichiers Git dans une configuration distante.

Configuration de gitfs_remotes

Vous pouvez spécifier une ou toutes les URL telles que git: //, https: //, file: // ou ssh: // pour la configuration gitfs_remotes dans le fichier maître. Ceci est utilisé pour rechercher les fichiers demandés.

La spécification d'URL https simple est définie ci-dessous.

gitfs_remotes:
   - https://github.com

le ssh la configuration peut être effectuée comme indiqué ci-dessous.

gitfs_remotes:
   - [email protected]:user1/sample.git
   - ssh://[email protected]/path/to/sample.git

Maintenant, nous avons configuré le serveur de fichiers Git en utilisant les deux options fileserver_backend et gitfs_remotes.

Redémarrer Master

Après avoir effectué toutes les modifications dans le fichier maître, redémarrez maintenant le maître pour charger toutes les configurations dans le serveur de fichiers Git.

Configuration de plusieurs télécommandes

La commande suivante est utilisée pour la configuration multiple dans gitfs_remotes dans le fichier maître.

gitfs_remotes:
   - git://github.com/sample/sample1.git
   - https://github.com/sample/sample2.git
   - file:///root/user/sample

Ici, les référentiels sample1.git, sample2.git, et sample.doc peut avoir les fichiers suivants.

sample1.git:
   top.sls
   
sample2.git
   edit/vimrc
   
sample.doc
   edit/vimrc

le MinionFSest un serveur de fichiers spécial fourni par Salt pour que les sbires puissent échanger les fichiers entre eux. Les fichiers servis par le MinionFS sont les fichiers intentionnellement partagés par les serviteurs. Pour partager les fichiers, un Minion doit suivre les étapes ci-dessous.

  • Le serviteur source doit envoyer le fichier au maître de sel en utilisant le cp.push fonction.

  • Une fois que les fichiers sont poussés par le serviteur source, les fichiers déployés sont accessibles par tout autre serviteur à l'aide du serveur de fichiers MinionFS.

Activer le push

Par défaut, le transfert des fichiers par les serviteurs vers un maître est désactivé. Pour accepter les fichiers des serviteurs, le maître doit avoir l'option «file_recv» dans le fichier de configuration et sa valeur doit être définie surTrue. Par défaut, la valeur si "file_recv" estfalse.

file_recv: True

Une fois l'option activée, redémarrez le service maître.

Pousser des fichiers

Les Minions peuvent pousser les fichiers vers le maître. Il est exécuté par lecp.pushfonction. Cette fonction cp.push fournit un mécanisme simple pour pousser les fichiers par minion en utilisant l'identifiant de minion.

salt 'minion-id' cp.push /path/to/the/file

Ici, le minion-id est utilisé pour identifier quel serviteur pousse le fichier. Cette commande stockera le fichier dans un sous-répertoire nomméminions sous le master's cachedir. Habituellement, le chemin est - / var / cache / salt / master / minions.

Pour le serviteur, m1 et le fichier - /var/log/mylog.txt, le fichier sera stocké dans - /var/cache/salt/master/minions/m1/var/log/mylog.txt.

Activer MinionFS

Pour activer MinionFS, ajoutez simplement minion dans le paramètre de backend du serveur de fichiers comme indiqué dans le bloc de code suivant.

fileserver_backend:
   - roots
   - minion

Une fois que MinionFS est activé, les fichiers poussés des minions sont disponibles sous la forme -

salt://<minion-id>/path/to/pushed/file

Pour le serviteur, m1 et le fichier poussé - /var/log/mylog.txt, le fichier poussé sera servi à partir de salt: //m1/var/log/mylog.txt.

Ce minionFS peut être monté dans un répertoire spécial en utilisant la configuration suivante. Cela séparera les fichiers minionFS des autres fichiers et aidera à organiser les fichiers minion.

minionfs_mountpoint: salt://minionfs

Pour la configuration ci-dessus, le fichier sera disponible sous le minionfs répertoire en tant que - salt: //minionfs/m1/var/log/mylog.txt

Options avancées de MinionFS

Le MinionFS fournit également une option pour activer / désactiver la disponibilité des fichiers poussés d'un certain serviteur. Les options sontminionfs_whitelist, pour activer les serviteurs et minionfs_blacklist, pour désactiver les serviteurs.

minionfs_whitelist:
   - webserver
   - develop*
   - ‘mail\d+.mysite.com'

minionfs_blacklist:
   - testing

Dans la configuration ci-dessus, tous les serviteurs sauf testing sont autorisés à partager le fichier en utilisant minionFS.

  • Webserver1

  • Les sbires dont les identifiants correspondent à l'expression régulière se développent *

  • Minions dont les identifiants correspondent à l'expression régulière mail\d+.mysite.com.

  • Testing

Dans le prochain chapitre, nous apprendrons à utiliser Cron avec Salt.

Le sel peut être utilisé avec le Cronapplication. L'utilisation conjointe des deux applications offre une excellente opportunité d'automatiser Salt. Alors que Salt fournit une option pour exécuter des commandes à distance, Cron lui permet de s'exécuter de manière pré-programmée ou automatisée. Apprenons à utiliser Cron et Salt ensemble dans ce chapitre.

Qu'est-ce que Cron?

Cron est une application très utile dans l'environnement Linux. Il permet de prérégler une commande ou un script à exécuter à une date et une heure spécifiques. Il permet également d'exécuter une application à intervalles réguliers, par exemple tous les jours, toutes les semaines ou tous les premiers jours du mois.

Cron démarre lorsque le système démarre et vérifiez le /etc/crontabfichier pour les détails de configuration. Le fichier / etc / crontab a chaque application et sa planification dans une ligne distincte comme indiqué ci-dessous.

15 * * * * root echo "This command runs at 15 minutes past every hour"
15 10 * * * root echo "This command is run daily at 10:15 am"

Chaque ligne a les sept points d'entrée suivants, qui sont séparés par un espace et ils sont comme suit -

  • minute - minute de l'heure et est compris entre «0» et «59».

  • hour - heure et est spécifié au format 24 heures.

  • day_of_month- Jour du mois et est compris entre 1 et 31. Par exemple, le 10 e de chaque mois est de 10.

  • month - Un mois spécifié et est spécifié numériquement (0-12), ou comme nom du mois (par exemple mai).

  • day_of_week - Le jour de la semaine est spécifié numériquement (0-7) ou comme nom du jour (par ex. Soleil).

  • user - Compte utilisateur sous lequel la commande s'exécute.

  • cmd - La commande réelle et ses arguments.

Ici, * remplace, si rien n'est attribué.

Appel de sel (appel de sel)

Salt fournit une CLI (Command Line Interface), salt-callpour exécuter les modules dans le système minion local lui-même plutôt qu'à partir du serveur maître à l'aide de la commande salt. L'interface de ligne de commande salt call prend en charge toutes les options prises en charge par la commande salt, mais s'exécute localement.

Salt Caller a été initialement conçu pour prendre en charge le débogage, mais maintenant, il peut être utilisé comme une application autonome.

salt-call test.ping

Utilisation de Salt-Call dans cron

L'interface de ligne de commande salt-call est utile pour planifier une opération salt à l'aide de Cron. Par exemple, pour vérifier l'état du serviteur tous les jours à minuit, nous pouvons utiliser salt-call avec l'option - state.apply comme indiqué ci-dessous.

/etc/crontab

PATH = /bin:/sbin:/usr/bin:/usr/sbin:/usr/local/bin:/usr/local/sbin:/opt/bin
0 0 * * * salt-call state.apply

Ici,

  • le state.apply La fonction vérifiera le fichier de configuration de sel pour le serviteur et vérifiera si toutes les actions définies pour le serviteur sont correctement configurées.

  • La définition du chemin est une bonne pratique car la commande salt peut parfois ne pas être disponible dans le chemin système.

Dans le chapitre suivant, nous allons apprendre l'exécution à distance, qui est un concept fondamental de Salt.

L'un des concepts fondamentaux de Salt est l'exécution à distance. Salt peut exécuter des commandes sur des milliers de systèmes en quelques secondes. Salt utilise sa propre commande pour effectuer cette fonctionnalité. Voyons maintenant les différentes commandes Salt pour une exécution à distance dans le chapitre.

Commande de sel

La commande Salt permet au Salt Master de communiquer avec un ou plusieurs Salt minions. La syntaxe de base est la suivante,

salt '<target>' <module.function> [arguments]

La syntaxe de commande ci-dessus comprend les trois composants principaux suivants.

  • target - Il détermine quels systèmes sont appliqués par la commande.

  • module.function- C'est une commande. Les commandes se composent d'un module et d'une fonction.

  • arguments - Données supplémentaires nécessaires pour appeler la fonction.

Laissez-nous comprendre chacun des composants en détail.

Quel est le composant cible?

Target est un composant qui vous permet de filtrer les serviteurs (système géré) pour exécuter la fonction. Une commande simple utilisant le composant cible est définie ci-dessous.

salt '*' test.ping

Il produira ce qui suit output -

minion2:
   True
minion1:
   True

Ici, la cible ‘*’représente tous les systèmes gérés. Le 'test'voici un module et pingest une fonction. Ceci est utilisé pour tester le service ping dans le système distant. Nous découvrirons les différents modules et leurs fonctions dans les chapitres suivants.

Cibles utilisant un identifiant (serviteur)

Vous pouvez envoyer une commande à un serviteur spécifique en utilisant son iddans la cible. À la place d'utiliser'*', vous pouvez le remplacer en utilisant minion id. Il est défini ci-dessous.

salt 'minion1’ test.ping

Il produira ce qui suit output -

minion1:
   True

Cibles utilisant l'expression régulière

Les cibles peuvent être filtrées par expression régulière spécifique. Il est défini ci-dessous.

salt -E 'minion[0-9]' test.ping

Il produira ce qui suit output -

minion2:
   True
minion1:
   True

Cibles utilisant la liste

Les cibles peuvent être explicitement spécifiées dans une liste. Il est défini dans le bloc de code suivant.

salt -L 'minion1,minion2' test.ping

Il produira ce qui suit output -

minion2:
   True
minion1:
   True

Cibles par condition

Les cibles peuvent être combinées en une seule commande, comme indiqué dans le bloc de code ci-dessous.

salt -C 'G@os:Ubuntu and minion* or [email protected].*' test.ping

Il produira ce qui suit output -

minion1:
   True
minion2:
   True

Module et fonctions (module.function)

Salt peut exécuter des commandes shell; mettre à jour les packages et distribuer les fichiers, etc., dans tous ses systèmes gérés simultanément. Salt effectue ces opérations à l'aide de modules. Salt dispose de modules spéciaux pour toutes les fonctionnalités disponibles. Laissez-nous comprendre les différents modules Salt en utilisant un exemple simple dans ce chapitre.

Commande Shell

Salt exécute des commandes shell à distance sur plusieurs systèmes à l'aide du cmd.runcommander. lecmd est le module principal et run est l'une des fonctions disponibles dans le cmdmodule. lerun La fonction permet à toute commande shell d'être exécutée dans le système distant comme indiqué dans le bloc de code ci-dessous.

salt '*' cmd.run 'ls -l /etc'

Il produira ce qui suit output -

minion2:
   total 868
   drwxr-xr-x 7 root root    4096 Jan 26 22:10 X11
   drwxr-xr-x 3 root root    4096 Jan 26 21:02 acpi
   -rw-r--r-- 1 root root    2981 Jan 26 20:48 adduser.conf
   -rw-r--r-- 1 root root      10 Jan 26 21:04 adjtime
   drwxr-xr-x 2 root root    4096 Jan 26 22:10 alternatives
   drwxr-xr-x 3 root root    4096 Jan 26 20:53 apm
   drwxr-xr-x 3 root root    4096 Jan 26 21:02 apparmor
   drwxr-xr-x 9 root root    4096 Jan 26 21:02 apparmor.d
   drwxr-xr-x 3 root root    4096 Jan 26 21:02 apport
   drwxr-xr-x 6 root root    4096 Jan 29 07:14 apt
   drwxr-xr-x 2 root root    4096 Jan 26 22:10 at-spi2
……………
……………
minion1:
   total 868
   drwxr-xr-x 7 root root    4096 Jan 26 22:10 X11
   drwxr-xr-x 3 root root    4096 Jan 26 21:02 acpi
   -rw-r--r-- 1 root root    2981 Jan 26 20:48 adduser.conf
   -rw-r--r-- 1 root root      10 Jan 26 21:04 adjtime
   drwxr-xr-x 2 root root    4096 Jan 26 22:10 alternatives
   drwxr-xr-x 3 root root    4096 Jan 26 20:53 apm

   drwxr-xr-x 3 root root    4096 Jan 26 21:02 apparmor
   drwxr-xr-x 9 root root    4096 Jan 26 21:02 apparmor.d
   drwxr-xr-x 3 root root    4096 Jan 26 21:02 apport
   drwxr-xr-x 6 root root    4096 Jan 29 07:09 apt
   drwxr-xr-x 2 root root    4096 Jan 26 22:10 at-spi2
   -rw-r----- 1 root daemon   144 Oct 21  2013 at.deny
   -rw-r--r-- 1 root root    2177 Apr  9  2014 bash.bashrc
   -rw-r--r-- 1 root root      45 Mar 22  2014 bash_completion
……………
……………

Afficher l'utilisation du disque

Salt fournit un module spécial, diskpour obtenir les détails complets du disque du système géré. lediskmodule a un usage fonction pour interroger les détails.

salt '*' disk.usage

Il produira ce qui suit output -

minion1:
   ----------
   /:
      ----------
      1K-blocks:
         41251136
      available:
         37852804
      capacity:
         5%
      filesystem:
         /dev/sda1
      used:
         1662420
   /dev:
      ----------
      1K-blocks:
         503908
      available:
         503896
      capacity:
         1%
      filesystem:
         udev
      used:
         12
   /run:
      ----------
      1K-blocks:
         101780
      available:
         101412
      capacity:
         1%
      filesystem:
         tmpfs
      used:
         368
   /run/lock:
      ----------
      1K-blocks:
         5120
      available:
         5120
      capacity:
         0%
      filesystem:
         none
      used:
         0
   /run/shm:
      ----------
      1K-blocks:
         508884
      available:
         508872
      capacity:
         1%
      filesystem:
         none
      used:
         12
   /run/user:
      ----------
      1K-blocks:
         102400
      available:
         102400
      capacity:
         0%
      filesystem:
         none
      used:
         0
   /sys/fs/cgroup:
      ----------
      1K-blocks:
         4
      available:
         4
      capacity:
         0%
      filesystem:
         none
      used:
         0
   /vagrant:
      ----------
      1K-blocks:
         303114632
      available:
         252331440
      capacity:
         17%
      filesystem:
         none
      used:
         50783192
minion2:
   ----------
   /:
      ----------
      1K-blocks:
         41251136
      available:
         37852804
      capacity:
         5%
      filesystem:
         /dev/sda1
      used:
         1662420
   /dev:
      ----------
      1K-blocks:
         503908
      available:
         503896
      capacity:
         1%
      filesystem:
         udev
      used:
         12
   /run:
      ----------
      1K-blocks:
         101780
      available:
         101412
      capacity:
         1%
      filesystem:
         tmpfs
      used:
         368
   /run/lock:
      ----------
      1K-blocks:
         5120
      available:
         5120
      capacity:
         0%
      filesystem:
         none
      used:
         0
   /run/shm:
      ----------
      1K-blocks:
         508884
      available:
         508872
      capacity:
         1%
      filesystem:
         none
      used:
         12
   /run/user:
      ----------
      1K-blocks:
         102400
      available:
         102400
      capacity:
         0%
      filesystem:
         none
      used:
            0
   /sys/fs/cgroup:
      ----------
      1K-blocks:
         4
      available:
         4
      capacity:
         0%
      filesystem:
         none
      used:
         0
   /vagrant:
      ----------
      1K-blocks:
         303114632
      available:
         252331440
      capacity:
         17%
      filesystem:
         none
      used:
         50783192

Interfaces réseau

Salt fournit un module séparé, un réseau et une fonction, des interfaces à l'intérieur du module pour interroger les informations d'interface réseau sur les systèmes gérés.

salt '*' network.interfaces

Il produira ce qui suit output -

minion1:
   ----------
   eth0:
      ----------
      hwaddr:
         08:00:27:04:3e:28
      inet:
         |_
            ----------
            address:
               10.0.2.15
            broadcast:
               10.0.2.255
            label:
               eth0
            netmask:
               255.255.255.0
      inet6:
         |_
            ----------
            address:
               fe80::a00:27ff:fe04:3e28
            prefixlen:
               64
            scope:
               link
      up:
         True
   eth1:
      ----------
      hwaddr:
         08:00:27:34:10:52
      inet:
         |_
            ----------
            address:
               192.168.50.11
            broadcast:
               192.168.50.255
            label:
               eth1
            netmask:
               255.255.255.0
      inet6:
         |_
            ----------
            address:
               fe80::a00:27ff:fe34:1052
            prefixlen:
               64
            scope:
               link
      up:
         True
   lo:
      ----------
      hwaddr:
         00:00:00:00:00:00
      inet:
         |_
            ----------
            address:
               127.0.0.1
            broadcast:
               None
            label:
               lo
            netmask:
               255.0.0.0
      inet6:
         |_
            ----------
            address:
               ::1
            prefixlen:
               128
            scope:
               host
      up:
         True
minion2:
   ----------
   eth0:
      ----------
      hwaddr:
         08:00:27:04:3e:28
      inet:
         |_
            ----------
            address:
               10.0.2.15
            broadcast:
               10.0.2.255
            label:
               eth0
            netmask:
               255.255.255.0
      inet6:
         |_
            ----------
            address:
               fe80::a00:27ff:fe04:3e28
            prefixlen:
               64
            scope:
               link
      up:
         True
   eth1:
      ----------
      hwaddr:
         08:00:27:a7:31:8e
      inet:
         |_
            ----------
            address:
               192.168.50.12
            broadcast:
               192.168.50.255
            label:
               eth1
            netmask:
               255.255.255.0
      inet6:
         |_
            ----------
            address:
               fe80::a00:27ff:fea7:318e
            prefixlen:
               64
            scope:
               link
      up:
         True
   lo:
      ----------
      hwaddr:
         00:00:00:00:00:00
      inet:
         |_
            ----------
            address:
               127.0.0.1
            broadcast:
               None
            label:
               lo
            netmask:
               255.0.0.0
      inet6:
         |_
            ----------
            address:
               ::1
            prefixlen:
               128
            scope:
               host
      up:
         True

Module d'exécution sys.doc

Les fonctions Salt peuvent être envoyées au sys.docmodule d'exécution. Ceci est utilisé pour obtenir les détails sur n'importe quel module directement à partir de la ligne de commande. Les fonctions Salt sont auto-documentées. Toute la documentation de la fonction peut être récupérée auprès des serviteurs via la fonction sys.doc (), qui est définie ci-dessous.

salt '*' sys.doc

Arguments pour un appel de fonction

Les arguments sont utilisés pour fournir des données supplémentaires pour l'appel de fonction. Un exemple d'argument simple est donné ci-dessous.

salt '*' sys.doc pkg.install

Ici, l'argument pkg.install est un module pour installer des packages spécifiques.

Fonction Python

Les arguments sont des paramètres séparés par des espaces de la fonction. Il permet au code python d'être passé en arguments comme indiqué ci-dessous.

salt '*' cmd.exec_code python 'import sys;print sys.version'

Il produira ce qui suit output -

minion2:
   2.7.6 (default, Oct 26 2016, 20:30:19) 
   [GCC 4.8.4]
minion1:
   2.7.6 (default, Oct 26 2016, 20:30:19) 
   [GCC 4.8.4]

De même, vous pouvez utiliser des mots-clés facultatifs et le YAML format ainsi.

La gestion de la configuration est l'un des concepts les plus importants de SaltStack. Il est utilisé pour créer un modèle de configuration réutilisable, appeléstate. L'état décrit tout ce qui est nécessaire pour placer un composant système ou une application dans une configuration connue.

État du sel

L'état Salt est une configuration réutilisable pour une partie spécifique d'un système. Les états sont plus faciles à comprendre et à décrire à l'aide d'un simple YAML.

Créer un état de sel

Les états de sel sont faciles à créer. Créons un état simple dans ce chapitre. Accédez au répertoire "salt-vagrant-demo / saltstack / salt /" et créez un fichier nommésamples.sls et ajoutez-y les lignes suivantes.

samples.sls

install_network_packages:
   pkg.installed:
      - pkgs:
         - rsync
         - lftp
         - curl

Maintenant, enregistrez le fichier et exécutez la commande suivante dans Salt Master.

root@saltmaster:/home/vagrant# salt 'minion1’ state.apply samples

Ici, nous avons installé rsync, lftp et curl à travers le pkg.installed module utilisant l'état de sel dans un serviteur de sel, minion1. Si cela fonctionne correctement, vous pouvez voir la réponse comme indiqué ci-dessous.

Il produira ce qui suit output -

minion1:
----------
   ID: install_network_packages
   Function: pkg.installed
   Result: True
   Comment: All specified packages are already installed
   Started: 08:08:48.612336
   Duration: 545.385 ms
   Changes:

Summary for minion1
------------
Succeeded: 1
Failed:    0
------------
Total states run:     1
Total run time: 545.385 ms

Appliquer l'état du sel

Maintenant que nous avons créé un état en utilisant le fichier '.sls' et l'avons appliqué en l'appelant spécifiquement. Salt a un fichier d'état par défaut appelétop.slsfichier. Le fichier supérieur est utilisé pour appliquer plusieurs fichiers d'état aux serviteurs de Salt. Le fichier supérieur décrit où les états doivent être appliqués. Bien,States et le Top file travailler ensemble pour créer le cœur de la capacité de gestion de configuration de SaltStack.

Créons maintenant un simple fichier top.sls dans le répertoire saltstack/salt et ajoutez ce qui suit.

top.sls

base:
  '*':
      - common
   'minion1':
      - samples

Ici le state, communément applies à all system Etat, samples s'applique à minion1.

Ensuite, exécutez Salt Master et appliquez l'état comme indiqué ci-dessous.

root@saltmaster:/home/vagrant# salt '*' state.apply

Il produira ce qui suit output -

minion1:
----------
   ID: common_packages
   Function: pkg.installed
   Result: True
   Comment: All specified packages are already installed
   Started: 09:33:35.642355
   Duration: 588.21 ms
   Changes:

Summary for minion1
------------
Succeeded: 1
Failed:    0
------------
Total states run:     1
Total run time: 588.210 ms
minion2:
----------
   ID: common_packages
   Function: pkg.installed
   Result: True
   Comment: All specified packages are already installed
   Started: 09:33:35.890331
   Duration: 602.79 ms
   Changes:

Summary for minion2
------------
Succeeded: 1
Failed:    0
------------
Total states run:     1
Total run time: 602.790 ms

Appliquer la taille du lot

Si vous avez un grand nombre de serviteurs connectés, vous pouvez limiter le nombre de systèmes mis à jour à la fois. Elle est effectuée en utilisant le–batch-size option, qui est définie ci-dessous.

root@saltmaster:/home/vagrant# salt --batch-size 5 '*' state.apply

Il produira ce qui suit output -

Executing run on ['minion2', 'minion1']
jid:
   20170314094638482664
minion1:
----------
   ID: common_packages
   Function: pkg.installed
   Result: True
   Comment: All specified packages are already installed
   Started: 09:46:41.228519
   Duration: 582.24 ms
   Changes:

Summary for minion1
------------
Succeeded: 1
Failed:    0
------------
Total states run:     1
Total run time: 582.240 ms
retcode:
   0
jid:
   20170314094638482664
minion2:
----------
   ID: common_packages
   Function: pkg.installed
   Result: True
   Comment: All specified packages are already installed
   Started: 09:46:41.153609
   Duration: 605.235 ms
   Changes:

Summary for minion2
------------
Succeeded: 1
Failed:    0
------------
Total states run:     1
Total run time: 605.235 ms
retcode:
   0

Fonctions d'état du sel

Les fonctions d'état Salt sont utilisées pour installer et configurer des applications sur votre système distant. Installons un package «Vim» en utilisant la fonction Salt state.

Créer et appliquer une fonction d'état

Créez un fichier nommé «sample.sls» dans le répertoire «salt-vagrant-demo / saltstack / salt / sample.sls» et ajoutez ce qui suit -

sample.sls

install vim:
   pkg.installed:
      - name: vim

Une fois que l'environnement Vagrant est en place, exécutez le salt master et appliquez le sample.sls en exécutant la commande suivante.

root@saltmaster:/home/vagrant# sudo salt 'minion2’ state.apply sample

Il produira ce qui suit output -

minion2:
----------
   ID: install vim
   Function: pkg.installed
   Name: vim
   Result: True
   Comment: Package vim is installed
   Started: 15:07:45.752764
   Duration: 553.506 ms
   Changes:

Summary for minion2
------------
Succeeded: 1
Failed:    0
------------
Total states run:     1
Total run time: 553.506 ms

Maintenant, nous avons ajouté un package «Vim». Testons maintenant le package en utilisant la méthode de test Salt.

Test de l'état du sel

Le test d'exécution est obligatoire en ajoutant l'option «test = True» aux états. Les informations de retour afficheront les états qui seront appliqués en jaune et le résultat sera signalé comme «Aucun».

La commande suivante est utilisée pour tester l'état -

root@saltmaster:/home/vagrant# sudo salt 'minion2’ state.apply sample test = True

Il produira ce qui suit output -

minion2:
----------
   ID: install vim
   Function: pkg.installed
   Name: vim
   Result: True
   Comment: Package vim is already installed
   Started: 15:07:45.752764
   Duration: 553.506 ms
   Changes:

Summary for minion2
------------
Succeeded: 1
Failed:    0
------------
Total states run:     1
Total run time: 553.506 ms

SaltStack ─ Composant Pilier

Le pilier est un élément essentiel pour rendre les états de sel réutilisables. Il est utilisé pour définir des données sécurisées pour les sbires affectés à l'aide de cibles. Les données du pilier de sel stockent des valeurs telles que les ports, les chemins de fichiers, les paramètres de configuration et les mots de passe.

Fichier de configuration de pilier

La configuration du pillar_roots dans le fichier de configuration principal est montré ci-dessous -

pillar_roots:
   base:
      - /srv/pillar

Ici, le fichier se trouve dans le répertoire «/ srv / pillar».

Considérez que le fichier supérieur situé dans /srv/pillar/top.sls a la structure suivante -

base:
   '*':
      - default

Maintenant, accédez au fichier default.sls situé dans /srv/pillar/default.sls et ajoutez le code suivant.

# Default pillar values
apache
git

Après avoir enregistré le fichier, actualisez le pilier pour mettre à jour toutes les modifications.

Rafraîchir le pilier

Vous pouvez actualiser le pilier à l'aide de la commande suivante.

root@saltmaster:/home/vagrant# salt '*' saltutil.refresh_pillar

La commande ci-dessus est utilisée pour actualiser les données du pilier de sel sur tous les serviteurs.

Liste des données piliers

Pour lister les données des piliers, vous pouvez utiliser la commande ci-dessous.

root@saltmaster:/home/vagrant# salt '*' pillar.ls

Il produira ce qui suit output -

minion2:
   - apache
   - git
minion1:
   - apache
   - git

Articles de pilier

Une fois le pilier configuré, les données peuvent être visualisées sur le serviteur via le module pilier. Il est accessible via la fonctionpillar.items, qui est défini ci-dessous.

root@saltmaster:/home/vagrant# salt '*' pillar.items

Il produira ce qui suit output -

minion2:
   ----------
   apache:
      httpd
   git:
      git
minion1:
   ----------
   apache:
      httpd
   git:
      git

SaltStack - Inclure le composant

Le composant 'Inclure' est utilisé pour définir la même tâche de configuration à plusieurs endroits. C'est facile à réaliser. En haut de votre fichier d'état, ajoutez une inclusion en utilisant le format suivant -

include:
   - state file 1 
   - state file 2

Ici, state file 1 et state file 2sont les noms des fichiers SLS que vous souhaitez inclure. Pas besoin d'inclure le.slsextension. Les états Salt Inclus sont insérés en haut du fichier actuel.

Fichier d'état dans le sous-répertoire

Vous pouvez inclure un fichier d'état de sous-répertoire à l'aide d'un point (.). Il agit comme un séparateur de répertoire.

include:
   - dir.sls1

Interface Grains

Grains est une interface utilisée pour dériver les informations sur le système sous-jacent. Les grains sont collectés pour le système d'exploitation, le nom de domaine, l'adresse IP, le noyau, le type de système d'exploitation, la mémoire et de nombreuses autres propriétés système.

Ciblage des céréales

Les données de grain peuvent être utilisées lors du ciblage des sbires, ce qui est défini dans le bloc de code suivant.

root@saltmaster:/home/vagrant# salt -G 'os:Ubuntu' test.ping

Il produira ce qui suit output -

minion1:
   True
minion2:
   True

Liste des céréales

Les grains peuvent être répertoriés en utilisant le module «grains.ls», défini ci-dessous.

root@saltmaster:/home/vagrant# salt '*' grains.ls

Éléments de liste

À l'instar de Pillar, les données sur les céréales peuvent également être répertoriées à l'aide de «grains.items».

root@saltmaster:/home/vagrant# salt '*' grains.items

La journalisation est utilisée pour suivre les événements logiciels en cours d'exécution. Un événement est décrit par un message descriptif, qui peut éventuellement contenir des données variables. L'approche de la journalisation du sel est utilisée pour obtenir tous les problèmes auxquels vous pourriez être confronté. Vous pouvez vérifier avec des niveaux de journal spécifiques.

Paramètres de configuration

Laissez-nous comprendre les différents paramètres de configuration pour la journalisation, en détail.

FICHIER JOURNAL

Les enregistrements du journal Salt sont transmis via le fichier, qui contient le nom du chemin local ou l'emplacement réseau pour l'identification. Ce fichier est considéré comme le fichier journal.

log_file: /var/log/salt/master

Ici, le fichier dépendant du binaire est exécuté dans master. De même, vous pouvez également exécuter dans le serviteur, comme indiqué ci-dessous.

log_file: /var/log/salt/minion

Vous pouvez également utiliser une adresse distante. La syntaxe pour utiliser l'adresse distante est - <file | udp | tcp>: // <host | socketpath>: <port-if-required> / <log-facility>.

log_file: udp://loghost:port

Ici, la fonction de journalisation est par défaut LOG_USER.

LOG_LEVEL

Les niveaux de journal sont classés dans une valeur attribuée numériquement. La bibliothèque Python a défini la plupart des niveaux de journalisation par défaut. En plus de cela, Salt utilise plus de niveaux. Certains des niveaux sont expliqués ci-dessous.

  • log_level: error; level value is 40 - Il indique l'enregistrement de l'instruction de journal en cas d'erreur.

  • log_level: quiet; level value is 1000 - Il indique que rien ne doit être enregistré à ce niveau.

  • log_level: info; level value is 20 - Il indique les informations normales du journal.

  • log_level: warn; level value is 30 - Il indique l'enregistrement de l'instruction de journal à l'avertissement.

  • log_level: debug; level value is 10 - Informations utiles pour déboguer les implémentations salt et le code salt.

  • log_level: trace; level value is 5 - Informations de débogage de code plus détaillées.

LOG_LEVEL_LOGFILE

Il définit le niveau des messages à envoyer au fichier journal.

log_level_logfile: info

LOG_DATEFMT

Il définit le format de la date du journal. Par défaut, il est représenté par% Y-% m-% d% H:% M:% S.

log_datefmt_logfile: '%Y-%m-%d %H:%M:%S'

LOG_FMT_CONSOLE

Il définit le format de la console enregistrant les messages. Salt utilise une coutumeLogRecordattributs pour coloriser la sortie du journal de la console. Il suit la syntaxe suivante -

'%(colorlevel)s'       # log level name colorized by level
'%(colorname)s'        # colorized module name
'%(colorprocess)s'     # colorized process number
'%(colormsg)s'         # colorized messages name

LOG_FMT_LOGFILE

Il définit le format du fichier journal enregistrant les messages. La syntaxe de base est la suivante -

%(asctime)s,%(msecs)03d [%(name)-17s][%(levelname)-8s] %(message)s

LOG_GRANULAR_LEVELS

Ce niveau est utilisé pour contrôler plus spécifiquement les niveaux de journalisation.

log_granular_levels:
   'salt': 'info'
   'salt.modules': ‘trace'

Ici, la bibliothèque de sel principale au niveau 'info' définit le salt.modules pour se connecter au niveau de la trace.

Gestionnaire de journalisation externe

Salt utilise le gestionnaire de journaux externe LogStash et Sentry pour la journalisation. Comprenons-le en détail dans ce chapitre.

Gestionnaire LOGSTASH

LogStash est une source ouverte; pipeline de traitement de données sécurisé côté serveur. Considérons un simple gestionnaire de journalisation UDP dans Salt qui utilise LogStash.

Spécifiez les modifications suivantes dans le fichier maître Salt -

logstash_udp_handler:
   host: 127.0.0.1
   port: 9999
   version: 1
   msg_type: logstash

Ajoutez ensuite les modifications dans le fichier de configuration de Logstash -

input {
   udp {
      port ⇒ 9999
      codec ⇒ json
   }
}

Ici, UDP - est l'entrée qui doit avoir un format comme json_event, qui est ce que nous envoyons sur le fil.

Gestionnaire de journalisation SENTRY

Sentry est un suivi des erreurs en temps réel dans les déploiements de production et des informations pour reproduire et corriger les plantages. La configuration par défaut dans le fichier maître est définie ci-dessous.

sentry_handler:
   dsn: https://pub-key:[email protected]/app-id
   log_level: debug

Ici, le niveau de journalisation par défaut pour le gestionnaire de sentinelle est ERREUR, mais nous avons défini le débogage log_level sous la clé de configuration sentry_handler.

Salt exécute des commandes dans un système distant en utilisant salt-minion. C'est le comportement normal. Dans certains scénarios, le système distant n'est accessible que par le protocole SSH. Pour ces scénarios, Salt fournit une option pour connecter le système distant à l'aide du protocole SSH uniquement et exécuter la commande via la couche SSH.

Salt SSHest très simple à configurer. La seule configuration nécessaire est de spécifier les détails du système distant dans un fichier spécial appeléRoster file. Ce fichier de liste se trouve normalement dans/etc/salt/roster. Le fichier de liste contiendra toutes les informations concernant le système distant et comment pouvons-nous nous y connecter. Une fois les fichiers de liste configurés, toutes les commandes Salt sont exécutées à l'aide dusalt-ssh au lieu de la commande salt.

Fichier de liste

Le système de liste est conçu spécifiquement pour Salt SSH. Ceci est conçu comme un système enfichable. Le seul but du système de fichiers est de recueillir des informations sur le système distant. Le fichier de liste est unYAML based configuration file contenant les informations du système distant comme targets. Ces cibles sont une structure de données spéciale avec un ensemble prédéfini d'attributs. Un fichier de liste contient une ou plusieurs cibles et chaque cible est identifiée par unSalt ID.

La structure de base du fichier de liste est la suivante -

<Salt ID>:
   host: <host name>
   user: <user name>
   passwd: <password of the user>

Tous les autres attributs pris en charge par le fichier de liste sont facultatifs. Ils sont les suivants -

  • port - Numéro de port SSH.

  • sudo - exécuter la commande via sudo.

  • sudo_user - nom d'utilisateur sudo.

  • tty - vrai si sudo est activé.

  • priv - clé privée.

  • timeout - timeout pour une connexion SSH.

  • minion_opts - dictionnaire des choix de minion.

  • thin_dir - répertoire de stockage du système cible pour les composants Salt.

  • cmd_umask - umask pour forcer la commande salt-call.

L'exemple de fichier de liste est le suivant -

web:
   host: 192.168.2.1
   user: webuser
   passwd: secret
   sudo: True   
db:
   host: 192.168.2.2

Déployer les clés SSH

Salt SSH générera une paire de clés publique / privée par défaut pour les connexions SSH. Le chemin par défaut sera /etc/salt/pki/master/ssh/salt-ssh.rsa. Cette clé peut être déployée sur le système distant à l'aide dussh-copy-id comme indiqué ci-dessous.

ssh-copy-id -i /etc/salt/pki/master/ssh/salt-ssh.rsa.pub [email protected]

Exécuter la commande

L'exécution d'une commande salt est aussi simple que de changer le salt cli commande dans salt-ssh comme indiqué ci-dessous.

salt-ssh '*' test.ping

Commande Shell brute

Salt SSH fournit une option (-r) pour exécuter une commande brute dans le système distant en contournant le module salt et les fonctions.

salt-ssh '*' -r 'ls'

Ciblage avec Salt SSH

Le ciblage du système distant dans Salt SSH ne prend en charge que les cibles glob et regex. Étant donné que Salt SSH est un module séparé, il ne fournit que des options limitées pour le moment et fournira plus de fonctionnalités dans un proche avenir.

Salt fournit un module séparé, Salt Cloud pour fournir des machines virtuelles de divers fournisseurs de cloud comme Amazon AWS, Google Compute, etc. Salt Cloud est une interface générique pour configurer et gérer les VM de divers fournisseurs de cloud.

  • Cloud Config- Le fichier de configuration principal de Salt Cloud est / etc / salt / cloud et il s'applique à toutes les VM. Le fichier de configuration principal est appeléCloud Config.

  • Cloud Providers - Pour cibler des fournisseurs de cloud spécifiques, nous pouvons utiliser un fichier de configuration spécifique et ils se trouvent dans /etc/salt/cloud.providers.d/*.conf, ils sont appelés comme Cloud Providers.

  • Cloud Profiles - Pour cibler une VM spécifique, nous pouvons également utiliser un fichier de configuration spécial, qui s'applique uniquement à cette VM particulière et ils se trouvent dans /etc/salt/cloud.profiles.d/*.conf, ils sont appelés comme Cloud Profiles.

Pour une machine virtuelle, les paramètres du Cloud Config est appliqué en premier, puis dans le Cloud Providers et enfin le remplacement est effectué par le Cloud Profiles.

Installation de Salt Cloud

Par défaut, Salt Cloud est intégré au Salt et est facilement disponible. S'il n'est pas disponible, nous pouvons l'installer en utilisant la commande ci-dessous.

pip install salt-cloud

Puisque Salt Cloud est un module séparé et s'exécute dans son propre processus, il peut également être installé dans le système Salt Minion au lieu du Salt Master.

Provisionnement d'une machine virtuelle

Pour provisionner une machine virtuelle, nous devons définir un fournisseur de cloud et un profil de cloud. Une fois les deux créés, nous pouvons provisionner une nouvelle machine virtuelle pour l'utiliser.

Fournisseur cloud

Les informations sur l'hôte cloud sont configurées dans le fichier de configuration du fournisseur cloud. Normalement, les informations de base qui doivent être configurées sont le pilote cloud, le nom d'utilisateur, le mot de passe, la clé privée, etc. Créons un nouveau fournisseur cloud nommémy-amazon-cloud.

  • Créez un fichier, my-amazon-cloud.conf sous /etc/salt/cloud.providers.d/

  • Ajouter un nouveau fournisseur à l'aide du ec2 chauffeur.

my-amazon-cloud:
   driver: ec2
   id: '<AWS_ID>'
   key: '<AWS_KEY>'
   private_key: /path/to/privatekey.pem
   keyname: <name of the key>
   securitygroup: default

   minion:
      master: <master server>

Salt fournit des pilotes prêts à l'emploi pour divers hôtes cloud, tels que GoGrid, HP Cloud, Google Compute Engine (GCE), Amazon AWS, Joyent, Linode, OpenNebula, ProfitBricks, Proxmox, Saltify, VexxHost, VMWare, etc.

Une fois les fournisseurs de cloud configurés, nous pouvons interroger l'emplacement disponible du fournisseur, les images de machine disponibles et ses différentes tailles.

salt-cloud --list-location my-amazon-cloud
salt-cloud --list-images my-amazon-cloud
salt-cloud --list-sizes my-amazon-cloud

Profil cloud

Un profil Cloud spécifie l'image et la taille de la machine virtuelle. Il peut être configuré sous - /etc/salt/cloud.profiles.d/. Créons un profil simple,simple.conf.

aws_micro:
   provider: my-amazon-cloud
   image: <image_id>
   size: <machine_id e.g. t1.micro>

Machine virtuelle

Une fois le fournisseur et les profils configurés, nous pouvons facilement fournir une machine virtuelle en utilisant le nuage de sel comme indiqué ci-dessous.

salt-cloud -p aws_micro master minion1 minion2

Où, p - Le nom de profil master, minion1 et minion2 sont les nouvelles machines virtuelles.

Les détails de la machine virtuelle nouvellement créée peuvent être obtenus à l'aide de la commande suivante.

salt-cloud --query

Les machines virtuelles peuvent être détruites à l'aide de la commande suivante -

slat-cloud -d master minion1

Carte des nuages

Une Cloud Map est un format spécial permettant de créer plusieurs machines virtuelles à la fois. Le format du fichier de carte consiste à spécifier le profil, puis à ajouter une liste des machines virtuelles en dessous.

Un exemple de fichier de carte est le suivant -

micro:
   - web1
   - web2
large:
   - db1
   - db2

Le fichier de carte peut être passé en tant qu'argument à la commande salt-cloud pour créer la machine virtuelle comme suit -

salt-cloud -m /path/to/mapfile

Il existe de nombreux périphériques tels que les routeurs, les équipements réseau, etc., ayant un système d'exploitation personnalisé, une mémoire limitée et des considérations de sécurité élevées. Dans ces appareils, nous n'avons pas pu installer la normesalt-minionet, par la suite, n'ont pas pu gérer ces systèmes. Cependant, Salt fournit une technologie innovante pour surmonter cette contrainte.

Salt a un module séparé, salt proxy minion qui contrôle le système distant à l'aide du service REST exécuté dans le système distant. Ce service REST est un service Web basé sur HTTP écrit à l'aide duRepresentational State Transfer (REST) concept et ils sont à la fois faciles à mettre en œuvre et à consommer.

Chaque appareil aura son propre SDK et son propre environnement de développement pour écrire des applications complexes. Salt s'attend à ce qu'un service REST soit développé dans l'appareil conformément aux spécifications de l'interface Salt. Salt fournit également un module python pour écrire le service Web REST. Si l'appareil prend en charge python, il sera alors facile de développer le service Web REST.

Une fois le service Web REST développé et déployé dans le système distant, Salt peut être configuré pour contrôler le périphérique distant à l'aide du service Web REST au lieu du minion salt.

Exemple de travail

Apprenons le concept de salt proxy minionen utilisant un environnement de travail en direct. Pour l'environnement live, nous avons choisi un système Linux pour le maître et le proxy minion. Nous allons contrôler le système en utilisant le service Web REST au lieu de salt-minion.

Installer et configurer le service Web REST

Salt fournit un exemple de l'implémentation du service Web REST, qui est nommé proxyminion_rest_example dans son module contrib. Laissez-nous installer l'exemple de service Web.

  • Installer ‘bottle’en utilisant le pip. lebottle command est un framework web python pour développer une application web.

pip install bottle = 0.12.8
  • Téléchargez le saltstack/salt-contribprojet de github. Sinon, clonez le projet à l'aide de la commande suivante.

git clone https://github.com/saltstack/salt-contrib
  • Ouvrez un terminal et accédez au salt-contrib annuaire.

  • Ce répertoire salt-contrib aura un dossier, proxyminion_rest_example. Ce dossier contient un exemple d'implémentation pour le service Web REST. Accédez au dossier proxyminion_rest_example.

  • Exécutez la commande suivante pour démarrer le service Web REST.

python rest.py --address <your ip address> --port 8000
  • Ouvrez un navigateur et chargez http: // «votre adresse IP»: 8000. Cela affichera la page par défaut avec les services et les packages, comme indiqué dans la capture d'écran ci-dessous.

Maintenant, nous avons configuré le service Web REST et il vérifiera comment configurer le proxy salt pour interroger le service Web REST et contrôler le système.

Configurer Salt-Proxy

Pour configurer le Salt-Proxy, nous devons suivre les étapes ci-dessous.

  • Nous devons spécifier le nœud maître pour le salt-proxy. Modifiez l'emplacement du fichier de configuration proxy, qui se trouve dans / etc / salt / proxy, et entrez le code suivant.

master: <your ip address>
  • Modifier / créer un fichier de pilier de base dans /srv/pillar/top.sls comme indiqué dans le bloc de code suivant.

base:
  'p8000':
      - p8000
  • Ajouter un nouveau fichier de pilier, p8000.sls dans le /srv/pillar comme indiqué dans le bloc de code ci-dessous.

proxy:
   proxytype: rest_sample
   url: http://<your ip address>:8000
  • Démarrez salt-proxy en mode débogage à l'aide de la commande suivante.

salt-proxy --proxyid = p8000 -l debug
  • Similaire au sel-minion, acceptez le salt-proxy key comme indiqué ci-dessous.

salt-key -y -a p8000

The following keys are going to be accepted:
Unaccepted Keys:
p8000
Key for minion p8000 accepted.

Courir le sel

Maintenant, exécutez le salt commande et appelez le ping.test fonction comme indiqué ci-dessous.

salt p8000 test.ping

Nous pouvons exécuter n'importe quelle fonction prise en charge par le service Web REST en utilisant salt, qui est similaire à salt-minion.

Par exemple, les informations de grain peuvent être obtenues à l'aide de la commande suivante.

salt p8000 grains.items

Le système d'événements de Salt est une interface locale ZeroMQ PUB, qui déclenche des événements salt. Elle est réalisée par les composants suivants.

  • Event Sockets - Il est utilisé pour publier des événements.

  • Event library - Il est utilisé pour écouter les événements et envoyer les événements dans le système de sel.

Événement Salt Master

Un maître Salt fournit différents types d'événements, qui sont expliqués en détail ci-dessous -

  • Événements d'authentification
  • Démarrer les événements
  • Les évènements clés
  • Événements de travail
  • Événements de coureurs
  • Événements de présence
  • Événements cloud

Passons en revue chacun des types d'événements en détail.

Événements d'authentification

Ces événements d'authentification se déclenchent lorsqu'un serviteur effectue une vérification d'authentification avec le maître. Il est représenté par salt / auth.

Début des événements

Les événements de démarrage se déclenchent chaque fois qu'un serviteur se connecte au maître Salt et il est représenté par salt / minion // start.

Les évènements clés

Les événements de clé sont déclenchés lorsque le maître du sel accepte et rejette les clés du serviteur de sel. Vous pouvez accéder à cet événement à l'aide de la commande salt-key.

Événements d'emploi

Un événement Job est déclenché chaque fois qu'un nouveau travail va démarrer. Il est représenté parsalt/job//new. Ici, JID - Job id new - new job

Événements de coureurs

Lorsqu'un coureur commence l'exécution, un événement de coureur est déclenché. Il est représenté par salt / run // new.

Événements de présence

Lorsque les serviteurs sont connectés ou nouvellement connectés ou déconnectés, cet événement est déclenché à intervalle régulier. Il est représenté par -salt/presence/present et salt/presence/change. Ici,

  • Present - signifie que le maître du sel est actuellement connecté à la liste des serviteurs.

  • Change - utilisé pour détecter un nouveau serviteur - connecté ou déconnecté.

Événements cloud

Les événements de nuage de sel sont déclenchés sur une machine virtuelle. Sauf autres événements, il n'est pas effectué sur le serviteur. Vous pouvez y accéder en utilisant -salt/cloud//creating. Il est déclenché lorsqu'un nuage Salt démarre le processus d'exécution de la machine virtuelle.

Outils d'événement

Maintenant, passons en revue les outils et scripts d'événements. Vous pouvez accéder au bus d'événements à l'aide de la CLI. Il est accessible par la commande suivante.

salt-run state.event pretty = True

Ici, le runner est conçu pour interagir avec le bus d'événements à partir d'outils externes et de scripts shell. Le bus événementiel de Salt est accessible à distance via leREST API. Il est représenté par - (exemple d'URL).

curl -SsNk https://salt-api.example.com:8000/events?token = 05A3.

De même, vous pouvez également accéder aux événements à partir des scripts Python.

En général, orchestrationest une coordination et un agencement automatisés des systèmes. Orchestrate runner est utilisé pour effectuer l'orchestration dans SaltStack.

Orchestration Runner

il Orchestrate Runner offre toutes les fonctionnalités du OverState(système précédent). Il est à l'origine appelé comme lestate.slscoureur. Ce runner d'orchestration est utilisé pour généraliser le système d'état Salt à un contexte de maître Salt.

le state.sls et le state.highstate les fonctions sont exécutées sur chaque serviteur Salt, mais les state.orchestraterunner est exécuté sur le maître. lestate.orchestraterunner vous permet de gérer l'intégralité de votre infrastructure en tant qu'état. Comprenons comment passer par un processus d'exécution simple.

Exécution simple

La commande Orchestrate Runner est identique à state.sls , mais vous pouvez l'exécuter avec la fonction «salt-run» au lieu de salt.

Supposons que vous ayez un sample.sls fichier situé à /srv/salt/orch/samples.sls. Ajoutez le code suivant dans ce fichier.

sample.sls

install_nginx:
   salt.state:
      - tgt: 'web*'
      - sls:
         - nginx

La commande suivante est utilisée pour s'exécuter sur le maître et elle appliquera les états définis dans ce fichier.

salt-run state.orchestrate orch.sample

Il produira ce qui suit output -

saltmaster.local_master:
----------
   ID: install_nginx
   Function: salt.state
   Result: True
   Comment: States ran successfully.
   Started: 11:54:56.308078
   Duration: 63.401 ms
   Changes:

Summary for saltmaster.local_master
------------
Succeeded: 1
Failed:    0
------------
Total states run:     1
Total run time:  63.401 ms
root@saltmaster:/home/vagrant#

Ici, selon la version actuelle, la fonction runner a été renommée en state.orchestrate. Cela sera utile pour éviter toute confusion avec la fonction d'exécution state.sls, mais les versions précédentes destate.sls doit être utilisé.

Exécuter la fonction

Pour exécuter une fonction, vous devez utiliser le salt.function. Considérez un fichierdata.sls situé à /srv/salt/orch/data.sls. Maintenant, ajoutez les modifications suivantes dans ce fichier.

data.sls

cmd.run:
   salt.function:
      - tgt: '*'
      - arg:
         - rm -rf /tmp/data

La commande suivante est utilisée pour exécuter la fonction Salt.

root@saltmaster:/home/vagrant# salt-run state.orchestrate orch.data

Il produira ce qui suit output -

saltmaster.local_master:
----------
   ID: cmd.run
   Function: salt.function
   Result: True
   Comment: Function ran successfully. Function cmd.run ran on minion1, minion2.
   Started: 12:14:54.791635
   Duration: 234.615 ms
   Changes:
      minion1:

      minion2:
Summary for saltmaster.local_master
------------
Succeeded: 1 (changed = 1)
Failed:    0
------------
Total states run:     1
Total run time: 234.615 ms

Les formules Salt sont emballées et distribuées aux maîtres Salt à l'aide du gestionnaire de packages. Ce concept a été influencé parRPM, Yum et Pacmansystèmes d'emballage. L'état du sel, le pilier, les modèles de fichiers et d'autres fichiers sont utilisés par la formule, puis regroupés dans un seul fichier.

Une fois le package de formules créé, il est copié dans le Repository System pour être utilisé pour les maîtres Salt. Avant de passer au gestionnaire de paquets, voyons comment installer un paquet «nginx» en utilisant la commande Salt basic.

La syntaxe suivante est utilisée pour installer un package «nginx».

root@saltmaster:/home/vagrant# salt '*' pkg.install nginx

Ici le pkg.install nginxLa commande est utilisée pour installer un package. Après l'exécution, vous verrez la réponse suivante.

Il produira ce qui suit output -

minion2:
   ----------
   httpd:
      ----------
      new:
         1
      old:
   httpd-cgi:
      ----------
      new:
         1
      old:
   libxslt1.1:
      ----------
      new:
         1.1.28-2build1
      old:
   nginx:
      ----------
      new:
         1.4.6-1ubuntu3.7
      old:
   nginx-common:
      ----------
      new:
         1.4.6-1ubuntu3.7
      old:
   nginx-core:
      ----------
      new:
         1.4.6-1ubuntu3.7
      old:
minion1:
   ----------
   httpd:
      ----------
      new:
         1
      old:
   httpd-cgi:
      ----------
      new:
         1
      old:
   libxslt1.1:
      ----------
      new:
         1.1.28-2build1
      old:
   nginx:
      ----------
      new:
         1.4.6-1ubuntu3.7
      old:
   nginx-common:
      ----------
      new:
         1.4.6-1ubuntu3.7
      old:
   nginx-core:
      ----------
      new:
         1.4.6-1ubuntu3.7
      old:

Maintenant, vous avez installé un package. Pour démarrer les services de ce package, utilisez la commande ci-dessous.

root@saltmaster:/home/vagrant# salt '*' service.start nginx

Après avoir exécuté cette commande, le résultat ressemble à celui indiqué dans le bloc de code ci-dessous.

minion1:
   True
minion2:
   True

Par conséquent, nous avons installé et démarré les services du package «nginx» à l'aide de la commande de base. Voyons maintenant comment construire et installer des packages dans le gestionnaire de packages Salt.

Construire des packages

Les packages peuvent être construits sur n'importe quel système sur lequel vous pouvez installer Salt. Il existe trois types de packages et ils sont les suivants.

  • Formula
  • Reactor
  • Conf

Voyons maintenant comment construire des packages en utilisant le Fomula Fichier.

Fichier de formule

La plupart des fichiers du paquet se trouvent dans le répertoire - / srv / spm / salt / par défaut, mais le fichier pillar peut être placé dans le répertoire - / srv / spm / pillar /. Le fichier Formula décrit le package.

Example

name: apache
os: RedHat
os_family: RedHat
version: 201607
release: 2
summary: Formula for installing Apache
description: Formula for installing Apache

Ici,

  • Name- Le nom du package. Ici, le nom du package estapache.

  • os - Il est utilisé pour savoir quels systèmes d'exploitation peuvent prendre en charge ce package.

  • os_family - Il permet de savoir quelles familles de systèmes d'exploitation peuvent prendre en charge ce package.

  • Version- La version du package. Il est spécifié au format AAAAMM.

  • Release - Ce champ se réfère principalement à une version d'une version.

  • Summary - Description en courtes lignes du package.

  • Description - Une description plus détaillée du package.

RÉACTEUR

Les dossiers du réacteur résident dans le /srv/spm/reactor/ annuaire.

CONF

Les fichiers de ce type de package sont des fichiers de configuration pour Salt, qui vivent normalement dans le /etc/salt/annuaire. Les fichiers de configuration des packages autres que Salt peuvent et doivent être traités avec un état Salt (en utilisant un type de package de formule).

Continuons avec les étapes suivantes pour créer un package.

  • Créez un fichier FORMULA et placez-le à la racine du dossier du package.

  • Assemblez les fichiers de formule dans un dossier sur le système de construction.

  • Courir spm build. Le package est généré et placé dans le dossier / srv / spm_build. La commande suivante est utilisée pour créer un package.

spm build /path/to/salt-packages-source/formula
  • Maintenant, copiez le .spm fichier dans un dossier du système de référentiel.

  • Vous pouvez partager le srv/spm_build sur le réseau, ou copiez les fichiers sur votre FTP ou sur le serveur Web.

  • Générez des métadonnées de référentiel à l'aide de la commande suivante.

spm create_repo /srv/spm_build

Installer des packages

Cette section explique comment installer les packages du gestionnaire de packages Salt.

Configurer les référentiels distants

Pour configurer des référentiels distants, Salt Master doit savoir où se trouve le référentiel via un processus de configuration.

Les fichiers sont dans le /etc/salt/spm.repos.d/spm.repo annuaire.

Example

file_repository:
   url: https://spm.example.com/

Ici, le fichier contient le nom du référentiel et le lien vers le référentiel. Vous pouvez également utiliser http, https, ftp ou le chemin du fichier. Pour utiliser le chemin du fichier, vous pouvez y accéder en utilisant l'URL: file: /// srv / spm_build.

Mettre à jour les métadonnées

Une fois le référentiel configuré sur Salt Master, les métadonnées du référentiel sont téléchargées à l'aide de la commande ci-dessous.

spm update_repo

Mettre à jour les racines des fichiers

Les packages SPM se trouvent dans le répertoire srv / spm / salt. Ajoutez le chemin suivant aux racines du fichier sur le Salt Master,

file_roots:
   base:
      1. /srv/salt
      2. /srv/spm/salt

Maintenant, redémarrez le maître de sel.

Installer le package Apache

Pour installer le package apache, utilisez la commande suivante.

spm install apache

Vous pouvez également installer directement à partir du fichier SPM en utilisant la commande ci-dessous.

spm local install /srv/spm/apache-201607-1.spm

Suppression d'un package

Pour supprimer un package, par exemple - apache, utilisez la commande suivante,

spm remove apache

Notez que si des fichiers ont été modifiés, ils ne seront pas supprimés.

Salt fournit un accès par programme à toutes ses commandes. Salt fournit différents modules pour chaque section du système Salt. Apprenons les bases de l'API python et comment exécuter les commandes salt de base de ce chapitre.

Configuration

le salt.config Le module est utilisé pour accéder aux détails de configuration de Salt.

import salt.config
opts = salt.config.client_config('/etc/salt/master')

Ici le client_config lit le fichier de configuration de salt et renvoie les détails de la configuration sous forme de dictionnaire.

Chargeur

le salt.loader module est utilisé pour charger chaque module dans Salt comme les grains, les serviteurs, etc.

import salt.loader
opts = salt.config.minion_config('/etc/salt/minion')
grains = salt.loader.grains(opts)

Ici, grains lit les détails des grains dans le système Salt et le renvoie.

Module client

le salt.client module est utilisé pour exécuter les commandes salt, salt-call et salt-SSH par programmation.

Les classes python les plus importantes sont les suivantes -

  • salt.client.LocalClient
  • salt.client.Caller
  • salt.client.ssh.client.SSHClient

La fonction principale fournie par la plupart des modules client est cmd. Cette fonction encapsule les options CLI et les exécute, ce qui est similaire à la ligne de commande et renvoie les résultats sous forme de structures de données python.

Client local

Le LocalClient est utilisé pour envoyer des commandes du maître aux sbires de sel et renvoyer les résultats au maître.

import salt.client

local = salt.client.LocalClient()
local.cmd('*', 'test.ping')

Il produira ce qui suit output -

{'minion1': True, 'minion2': True }

Votre interlocuteur

L'appelant est utilisé pour exécuter salt-call par programme et renvoyer les résultats.

import salt.client
caller = salt.client.Caller()
caller.cmd('test.ping')

Il produira ce qui suit output -

True

SSHClient

Le SSHCient est utilisé pour exécuter le salt-ssh par programme et renvoyer les résultats.

import salt.client.ssh.client
ssh = salt.client.ssh.client.SSHClient()
ssh.cmd('*', 'test.ping')

Il produira ce qui suit output -

{'minion1': True, 'minion2': True }

CloudClient

Le module salt.cloud est utilisé pour exécuter les commandes salt-cloud par programmation.

client = salt.cloud.CloudClient(path = '/etc/salt/cloud')

Le module Cloud fournit des fonctions pour créer des VM (créer), pour détruire des VM (détruire), répertorier les images fournies par un fournisseur de cloud (list_images), répertorier les emplacements d'un fournisseur de cloud (list_locations), répertorier les tailles de machine d'un fournisseur de cloud (list_sizes), etc.

Dans cet exemple de travail, nous allons créer une formule Salt qui configurera le serveur Web Apache avec le logiciel PHP. Salt est un excellent moyen d'exécuter des commandes ad hoc, mais vous ne voudriez pas vraiment configurer continuellement votre infrastructure de cette façon. En créant un ensemble de formules Salt, vous pouvez reproduire de manière fiable n'importe quelle configuration.

Les formules Salt sont de simples fichiers texte YAML et résident par défaut sur votre Salt Master dans /srv/salt/*. Commençons par créer une formule Salt pour installer le serveur Web Apache et PHP en même temps.

Créez un fichier nommé «websetup.sls» sous /srv/salt/ répertoire et ajoutez le code suivant.

websetup.sls

websetup:
   pkg:
      - installed
      - pkgs:
         - apache2
         - php5
         - php5-mysql

Dans cet exemple, notez l'argument «- pkgs:». Chaque élément de la liste ci-dessous «- pkgs:» sera transmis ensemble au gestionnaire de paquets du système d'exploitation pour être installé ensemble. Chaque fois que vous avez une longue liste de packages à installer, c'est le moyen le plus efficace de les installer.

Appliquez cette formule à Salt Master à l'aide de la commande suivante.

root@saltmaster:/home/vagrant# salt 'minion2' state.sls websetup

Maintenant, vous verrez ce qui suit output -

minion2:
----------
   ID: websetup
   Function: pkg.installed
   Result: True
   Comment: 3 targeted packages were installed/updated.
   Started: 01:50:53.978396
   Duration: 86738.132 ms
   Changes:
      ----------
         apache2:
            ----------
            new:
               2.4.7-1ubuntu4.13
            old:
         apache2-api-20120211:
            ----------
            new:
               1
            old:
         apache2-bin:
            ----------
            new:
               2.4.7-1ubuntu4.13
            old:
         apache2-data:
            ----------
            new:
               2.4.7-1ubuntu4.13
            old:
         libapache2-mod-php5:
            ----------
            new:
               5.5.9+dfsg-1ubuntu4.21
            old:
         libapr1:
            ----------
            new:
               1.5.0-1
            old:
         libaprutil1:
            ----------
            new:
               1.5.3-1
            old:
         libaprutil1-dbd-sqlite3:
            ----------
            new:
               1.5.3-1
            old:
         libaprutil1-ldap:
            ----------
            new:
               1.5.3-1
            old:
         php5:
            ----------
            new:
               5.5.9+dfsg-1ubuntu4.21
            old:
         php5-cli:
            ----------
            new:
               5.5.9+dfsg-1ubuntu4.21
            old:
         php5-common:
            ----------
            new:
               5.5.9+dfsg-1ubuntu4.21
            old:
         php5-json:
            ----------
            new:
               1.3.2-2build1
            old:
         php5-mhash:
            ----------
            new:
               1
            old:
         php5-mysql:
            ----------
            new:
               5.5.9+dfsg-1ubuntu4.21
            old:
         php5-readline:
            ----------
            new:
               5.5.9+dfsg-1ubuntu4.21
            old:
         phpapi-20121212:
            ----------
            new:
               1
            old:
         ssl-cert:
            ----------
            new:
               1.0.33
            old:
Summary for minion2
------------
Succeeded: 1 (changed = 1)
Failed:    0
------------ 
Total states run:     1
Total run time:  86.738 s

Maintenant, vous avez installé les packages dans minion2.

Highstate

Un «highstate» est un moyen pour Salt de déterminer laquelle des formules de sel doit être appliquée à un certain serviteur. Exécutez un «highstate» à l'aide de la commande suivante.

root@saltmaster:/home/vagrant# salt <targets> state.highstate

top.sls

Lorsque le serviteur demande d'exécuter un état élevé, comme mentionné précédemment, le serviteur demande le top.sls au maître Salt et recherche les formules auxquelles il correspond. Par défaut, ce fichier se trouve dans /srv/salt/top.sls. Ajoutons notre formule au fichier top.sls et définissons minion2 comme cible.

base:
   '*':
      - common
   'minion2’:
      - websetup

Maintenant, exécutez le highstate ciblant minion2 comme indiqué ci-dessous.

root@saltmaster:/home/vagrant# salt 'minion2' state.highstate

Après avoir appliqué cela, vous pouvez voir ce qui suit output -

minion2:
----------
   ID: common_packages
   Function: pkg.installed
   Result: True
   Comment: All specified packages are already installed
   Started: 01:55:17.998824
   Duration: 461.615 ms
   Changes:

Summary for minion2
------------
Succeeded: 1
Failed:    0
------------
Total states run:     1
Total run time: 461.615 ms

Désormais, le serveur Web Apache et PHP sont installés dans le minion2. De cette façon, nous devons cibler les sbires en utilisant les deuxtop.sls et highstate et installez le logiciel requis avec un minimum de travail et une flexibilité maximale.