Chef - Scripts para bolsas de datos

En determinadas condiciones, no es posible poner el servidor bajo el control total de Chef. En tales casos, es posible que deba acceder a los valores en las bolsas de datos de Chef desde los scripts. Para hacer esto, es necesario almacenar los valores de la bolsa de datos en un archivo JSON y dejar que el script agregado acceda a esos valores.

Para ello, es necesario tener un libro de cocina. En nuestro caso, usaríamos test_cookbook como antes y deberíamos tener la lista de ejecución del nodo, incluida la definición de test_cookbook.

Método de trabajo

Step 1 - Crea una bolsa de datos.

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

Step 2 - Cree un elemento de bolsa de datos.

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

Step 3 - Actualice el elemento de la bolsa de datos.

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

Usar en el libro de cocina

Step 1 - Necesita crear un archivo JSON que contenga valores de bolsa de datos utilizando el libro de recetas anterior para que los scripts externos puedan acceder a esos valores.

[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 - Sube test_cookbook al servidor Chef.

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

Step 3 - Ejecute el cliente Chef en el 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 - Validar el contenido del archivo JSON generado.

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

Flujo de trabajo de scripts

En el comando anterior, el recurso de archivo que hemos utilizado que crea un archivo JSON dentro del /etcEl directorio está definido en el libro de recetas predeterminado. Obtiene el contenido del archivo directamente de la bolsa de datos utilizando el método data_bag_item. Accedemos a los valores del host desde el elemento de la bolsa de datos y lo convertimos a JSON. El recurso de archivo utiliza los valores convertidos a JSON como contenido y los escribe en el disco.