Chef - Chef-Shell

Pisanie książek kucharskich szefa kuchni jest zawsze trudne. To sprawia, że ​​jest to jeszcze trudniejsze ze względu na długi cykl sprzężenia zwrotnego przesyłania ich na serwer Chef, udostępnianie maszyny wirtualnej włóczęgi, sprawdzanie, jak tam zawiodły, płukanie i powtarzanie. Byłoby łatwiej, gdybyśmy mogli wypróbować niektóre elementy lub przepisy, zanim wykonamy te wszystkie ciężkie prace naraz.

Chef jest wyposażony w Chef-Shell, który jest w zasadzie interaktywną sesją Ruby z Chefem. W Chef-Shell możemy stworzyć -

  • Attributes
  • Napisz przepisy
  • Inicjowanie uruchomień Chefa

Służy do oceny części przepisów w locie, przed przesłaniem ich na serwer Chef i wykonaniem kompletnych książek kucharskich w węźle.

Running Shell

Step 1 - Uruchom Chef-Shell w trybie samodzielnym.

mma@laptop:~/chef-repo $ chef-shell 
loading configuration: none (standalone chef-shell session) 
Session type: standalone 
Loading...[2017-01-12T20:48:01+01:00] INFO: Run List is [] 
[2017-01-12T20:48:01+01:00] INFO: Run List expands to [] 
done. 
This is chef-shell, the Chef Shell. 
Chef Version: 11.0.0 
http://www.opscode.com/chef 
http://wiki.opscode.com/display/chef/Home 
run `help' for help, `exit' or ^D to quit. 
Ohai2u mma@laptop!  
chef >

Step 2 - Przełącz na tryb atrybutów w Chef-Shell

  • chef > attributes_mode

Step 3 - Ustawienie wartości atrybutu.

  • chef:attributes > set[:title] = "Chef Cookbook"

    • „Książka kucharska szefa kuchni”

  • chef:attributes > quit

    • :attributes

  • chef >

Step 4 - Przełącz na tryb receptury.

  • chef > recipe_mode

Step 5 - Utwórz zasób plikowy.

chef:recipe > file "/tmp/book.txt" do 
chef:recipe > content node.title 
chef:recipe ?> end  

=> <file[/tmp/book.txt] @name: "/tmp/book.txt" @noop: nil @ 
before: nil @params: {} @provider: Chef::Provider::File @allowed_ 
actions: [:nothing, :create, :delete, :touch, :create_if_missing] 
@action: "create" @updated: false @updated_by_last_action: false 
@supports: {} @ignore_failure: false @retries: 0 @retry_delay: 
2 @source_line: "(irb#1):1:in `irb_binding'" @elapsed_time: 0 @ 
resource_name: :file @path: "/tmp/book.txt" @backup: 5 @diff: nil 
@cookbook_name: nil @recipe_name: nil @content: "Chef Cookbook">   

chef:recipe >

Step 6 - Uruchom program Chef, aby utworzyć plik z podaną zawartością.

  • chef:recipe > run_chef

[2017-01-12T21:07:49+01:00] INFO: Processing file[/tmp/book.txt] 
action create ((irb#1) line 1) 
--- /var/folders/1r/_35fx24d0y5g08qs131c33nw0000gn/T/cheftempfile20121212- 
11348-dwp1zs 2012-12-12 21:07:49.000000000 
+0100 
+++ /var/folders/1r/_35fx24d0y5g08qs131c33nw0000gn/T/chefdiff20121212- 
11348-hdzcp1 2012-12-12 21:07:49.000000000 +0100 
@@ -0,0 +1 @@ 
+Chef Cookbook 
\ No newline at end of file 
[2017-01-12T21:07:49+01:00] INFO: entered create 
[2017-01-12T21:07:49+01:00] INFO: file[/tmp/book.txt] created file 
/tmp/book.txt

Jak to działa

  • Chef-Shell zaczyna się od sesji Interactive Ruby (IRB) wzbogaconej o pewne specyficzne funkcje.

  • Oferuje tryby takie jak attribute_mode i interactive_mode.

  • Pomaga w pisaniu poleceń, które są zapisywane w przepisie lub książce kucharskiej.

  • Uruchamia wszystko w trybie interaktywnym.

Możemy uruchomić Chef-Shell w trzech różnych trybach: Standalone mode, Client mode, i Solo mode.

  • Standalone mode- To jest tryb domyślny. Nie załadowano żadnych książek kucharskich, a lista uruchomień jest pusta.

  • Client mode - Tutaj szef kuchni działa jako klient szefa kuchni.

  • Solo mode - Tutaj szef kuchni działa jako klient szefa kuchni solo.