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.