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.