Szef kuchni - skrypty do worków danych

W pewnych warunkach nie jest możliwe oddanie serwera pod pełną kontrolę Szefa Kuchni. W takich przypadkach może być konieczne uzyskanie dostępu do wartości w workach z danymi szefa kuchni ze skryptów. Aby to zrobić, należy przechowywać wartości zbioru danych w pliku JSON i pozwolić dodanemu skryptowi na dostęp do tych wartości.

Do tego potrzebna jest książka kucharska. W naszym przypadku użylibyśmy test_cookbook jak wcześniej i powinniśmy mieć listę uruchomień węzła zawierającą definicję test_cookbook.

Metoda pracy

Step 1 - Utwórz pakiet danych.

vipin@laptop:~/chef-repo $ mkdir data_bags/servers 
vipin@laptop:~/chef-repo $ knife data bag create servers 
Created data_bag[servers]

Step 2 - Utwórz element zestawu danych.

vipin@laptop:~/chef-repo $ subl data_bags/servers/Storage.json { 
   "id": "storage", 
   "host": "10.0.0.12" 
}

Step 3 - Zaktualizuj element zestawu danych.

vipin@laptop:~/chef-repo $ subl data_bags/servers/Storage.json { 
   "id": "storage", 
   "host": "10.0.0.12" 
}

Używanie w książce kucharskiej

Step 1 - Należy utworzyć plik JSON zawierający wartości zbioru danych przy użyciu powyższej książki kucharskiej, aby zewnętrzne skrypty miały dostęp do tych wartości.

vipin@laptop:~/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 - Prześlij test_cookbook na serwer Chef.

vipin@laptop:~/chef-repo $ knife cookbook upload test_cookbook 
Uploading my_cookbook [0.1.0]

Step 3 - Uruchom klienta Chef w węźle.

user@server:~$ 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 - Walidacja zawartości wygenerowanego pliku JSON.

user@server:~$ cat /etc/backup_config.json 
"10.0.0.12"

Przepływ pracy skryptów

W powyższym poleceniu zasób pliku, którego użyliśmy, który tworzy plik JSON wewnątrz /etckatalog jest zdefiniowany w domyślnej książce kucharskiej. Pobiera zawartość pliku bezpośrednio z pakietu danych za pomocą metody data_bag_item. Uzyskujemy dostęp do wartości hosta z elementu pakietu danych i konwertujemy go na JSON. Zasób plikowy używa wartości przekonwertowanych na format JSON jako swojej zawartości i zapisuje je na dysku.