Chef - Script per i data bag

In determinate condizioni, non è possibile mettere il server sotto il pieno controllo di Chef. In questi casi, potrebbe essere necessario accedere ai valori nei data bag di Chef dagli script. Per fare ciò, è necessario memorizzare i valori del data bag in un file JSON e consentire allo script aggiunto di accedere a tali valori.

Per questo, è necessario avere un libro di cucina. Nel nostro caso useremmo test_cookbook come prima e dovremmo avere l'elenco di esecuzione del nodo inclusa la definizione di test_cookbook in esso.

Metodo di lavoro

Step 1 - Crea un data bag.

[email protected]:~/chef-repo $ mkdir data_bags/servers 
[email protected]:~/chef-repo $ knife data bag create servers 
Created data_bag[servers]

Step 2 - Crea un articolo nella borsa dati.

[email protected]:~/chef-repo $ subl data_bags/servers/Storage.json { 
   "id": "storage", 
   "host": "10.0.0.12" 
}

Step 3 - Aggiorna l'elemento della borsa dati.

[email protected]:~/chef-repo $ subl data_bags/servers/Storage.json { 
   "id": "storage", 
   "host": "10.0.0.12" 
}

Utilizzo in Cookbook

Step 1 - È necessario creare un file JSON contenente i valori del sacchetto di dati utilizzando il ricettario sopra in modo che gli script esterni possano accedere a tali valori.

[email protected]:~/chef-repo $ subl cookbooks/test_cookbook/recipes/default.rb 
file "/etc/backup_config.json" do 
   owner "root"
   group "root" 
   mode 0644 
   content data_bag_item('servers', 'backup')['host'].to_json 
end

Step 2 - Carica test_cookbook sul server Chef.

[email protected]:~/chef-repo $ knife cookbook upload test_cookbook 
Uploading my_cookbook [0.1.0]

Step 3 - Esegui il client Chef sul nodo.

[email protected]:~$ sudo chef-client 
...TRUNCATED OUTPUT... 
[2013-03-14T20:30:33+00:00] INFO: Processing 
file[/etc/backup_config.json] action create 
(my_cookbook::default line 9) 
[2013-03-14T20:30:34+00:00] INFO: entered create 
[2013-03-14T20:30:34+00:00] INFO: 
file[/etc/backup_config.json] owner changed to 0 
[2013-03-14T20:30:34+00:00] INFO: 
file[/etc/backup_config.json] group changed to 0 
[2013-03-14T20:30:34+00:00] INFO: 
file[/etc/backup_config.json] mode changed to 644 
[2013-03-14T20:30:34+00:00] INFO: 
file[/etc/backup_config.json] created file 
/etc/backup_config.json 
...TRUNCATED OUTPUT...

Step 4 - Convalida del contenuto del file JSON generato.

[email protected]:~$ cat /etc/backup_config.json 
"10.0.0.12"

Flusso di lavoro degli script

Nel comando precedente, la risorsa file che abbiamo utilizzato che crea il file JSON all'interno del file /etcdirectory è definita nel ricettario predefinito. Ottiene il contenuto del file direttamente dal data bag utilizzando il metodo data_bag_item. Accediamo ai valori host dall'elemento del data bag e lo convertiamo in JSON. La risorsa file utilizza i valori convertiti in JSON come contenuto e lo scrive sul disco.