Повар - Chef-Shell
Написание поваренных книг для шеф-поваров всегда сложно Это еще больше усложняет задачу из-за длительного цикла обратной связи: загрузки их на сервер Chef, подготовки бродячей виртуальной машины, проверки их сбоев, промывки и повторения. Было бы проще, если бы мы могли попробовать протестировать некоторые изделия или рецепты, прежде чем мы сразу возьмемся за всю эту тяжелую работу.
Chef поставляется с Chef-Shell, который по сути представляет собой интерактивный сеанс Ruby с Chef. В Chef-Shell мы можем создавать -
- Attributes
- Написать рецепты
- Инициализация запусков Chef
Он используется для оценки частей рецептов на лету, перед их загрузкой на сервер Chef и выполнением полных кулинарных книг на узле.
Бегущая оболочка
Step 1 - Запустите Chef-Shell в автономном режиме.
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 - Переключитесь в режим атрибутов в Chef-Shell
chef > attributes_mode
Step 3 - Установка значения атрибута.
chef:attributes > set[:title] = "Chef Cookbook"
"Поваренная книга"
chef:attributes > quit
:attributes
chef >
Step 4 - Перейти в режим рецепта.
chef > recipe_mode
Step 5 - Создайте файловый ресурс.
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 - Запустите Chef, чтобы создать файл с заданным содержимым.
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
Как это работает
Chef-Shell начинается с сеанса Interactive Ruby (IRB), дополненного некоторыми специфическими функциями.
Он предлагает такие режимы, как attribute_mode и interactive_mode.
Это помогает в написании команд, которые записываются внутри рецептов или поваренной книги.
Все работает в интерактивном режиме.
Мы можем запустить Chef-Shell в трех разных режимах: Standalone mode, Client mode, а также Solo mode.
Standalone mode- Это режим по умолчанию. Поваренные книги не загружены, а список выполнения пуст.
Client mode - Здесь шеф-повар выступает в роли повара-клиента.
Solo mode - Здесь шеф-повар выступает в роли клиента-шеф-повара.