SaltStack - Serveur de fichiers Salt

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.