SaltStack - API Python
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.