SaltStack - API Python
Salt fornisce l'accesso programmatico a tutti i suoi comandi. Salt fornisce diversi moduli per ogni sezione del sistema Salt. Impariamo le basi dell'API python e su come eseguire i comandi salt di base in questo capitolo.
Configurazione
Il salt.config viene utilizzato per accedere ai dettagli di configurazione di Salt.
import salt.config
opts = salt.config.client_config('/etc/salt/master')
Qui, il client_config legge il file di configurazione salt e restituisce i dettagli di configurazione come dizionario.
Caricatore
Il salt.loader modulo viene utilizzato per caricare ogni modulo in Salt come cereali, minion, ecc.
import salt.loader
opts = salt.config.minion_config('/etc/salt/minion')
grains = salt.loader.grains(opts)
Qui, grains legge i dettagli dei grani nel sistema del sale e li restituisce.
Modulo client
Il salt.client module viene utilizzato per eseguire i comandi salt, salt-call e salt-SSH a livello di codice.
Le classi python più importanti sono le seguenti:
- salt.client.LocalClient
- salt.client.Caller
- salt.client.ssh.client.SSHClient
La funzione principale fornita dalla maggior parte del modulo client è cmd. Questa funzione racchiude le opzioni CLI e le esegue, che è simile alla riga di comando e restituisce i risultati come strutture di dati Python.
LocalClient
Il LocalClient viene utilizzato per inviare comandi dal master ai minion del sale e restituire i risultati al master.
import salt.client
local = salt.client.LocalClient()
local.cmd('*', 'test.ping')
Produrrà quanto segue output -
{'minion1': True, 'minion2': True }
Caller
Il chiamante viene utilizzato per eseguire salt-call a livello di codice e restituire i risultati.
import salt.client
caller = salt.client.Caller()
caller.cmd('test.ping')
Produrrà quanto segue output -
True
SSHClient
Il SSHCient viene utilizzato per eseguire il salt-ssh a livello di codice e restituire i risultati.
import salt.client.ssh.client
ssh = salt.client.ssh.client.SSHClient()
ssh.cmd('*', 'test.ping')
Produrrà quanto segue output -
{'minion1': True, 'minion2': True }
CloudClient
Il modulo salt.cloud viene utilizzato per eseguire i comandi salt-cloud a livello di programmazione.
client = salt.cloud.CloudClient(path = '/etc/salt/cloud')
Il modulo cloud fornisce funzioni per creare VM (creare), distruggere VM (distruggere), elencare le immagini fornite da un fornitore di servizi cloud (list_images), elencare le posizioni di un fornitore di servizi cloud (list_locations), elencare le dimensioni della macchina di un fornitore di servizi cloud (list_sizes), eccetera.