Chef-レシピを動的に構成する

属性は、クックブックを動的に構成するための重要なコンポーネントです。属性を使用すると、作成者はクックブックを構成可能にすることができます。クックブックに設定されているデフォルト値をオーバーライドすることで、ユーザーは独自の値を挿入できます。

Step 1 −クックブック属性のデフォルトファイルを作成し、それにデフォルト属性を追加します。

vipin@laptop:~/chef-repo $ subl cookbooks/my_cookbook/attributes/default.rb 
default['my_cookbook']['message'] = 'hello world!'

Step 2 −レシピ内で属性を定義します。

vipin@laptop:~/chef-repo $ subl cookbooks/<Cookbook Name>/recipes/default.rb 
message = node['my_cookbook']['message'] 
Chef::Log.info("** Saying what I was told to say: #{message}")

Step 3 −変更されたクックブックをアップロードします。

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

Step 4 −定義されたノードのChef-Clientを実行しています。

user@server:~$ sudo chef-client 
...TRUNCATED OUTPUT... 
[2013-01-13T20:48:21+00:00] INFO: ** Saying what I was told to 
say: hello world! 
...TRUNCATED OUTPUT...

作業方法

Chefは、属性ファイルを実行する前に、属性ファイルからすべての属性をロードします。属性はノードオブジェクトとともに保存されます。レシピ内のノードオブジェクトに保存されているすべての属性にアクセスして、現在の値を取得できます。

Chefの構造は制限されており、デフォルトが最も低いものから始まり、通常(セットでエイリアス化されている)になり、オーバーライドされます。レシピで設定された属性レベルは、属性ファイルで設定された同じレベルよりも優先されます。

ノードおよび環境レベルでの属性のオーバーライド

ロールまたは環境で定義された属性が最も優先されます。

Step 1 −役割を作成します。

vipin@laptop:~/chef-repo $ subl roles/german_hosts.rb 
name "german_hosts" 
description "This Role contains hosts, which should print out 
their messages in German" 
run_list "recipe[my_cookbook]" 
default_attributes "my_cookbook" => { "message" => "Hallo Welt!" }

Step 2 −ロールをChefサーバーにアップロードします。

vipin@laptop:~/chef-repo $ knife role from file german_hosts.rb 
Updated Role german_hosts!

Step 3 −役割をノードに割り当てます。

vipin@laptop:~/chef-repo $ knife node edit server 
"run_list": [ 
   "role[german_hosts]" 
] 
Saving updated run_list on node server

Step 4 −Chef-Clientを実行します。

user@server:~$ sudo chef-client 
...TRUNCATED OUTPUT... 
[2013-01-13T20:49:49+00:00] INFO: ** Saying what I was told to 
say: Hallo Welt! 
...TRUNCATED OUTPUT...