Chef - 定義



定義可以定義為一種將資源進行邏輯分組的方法,這些資源會被反覆使用。在這個流程中,我們將資源進行分組併為其命名,以提高已定義 Cookbook 的可讀性。

為了做到這一點,我們需要一個菜譜。在本例中,我們使用 test_cookbook 和一個節點執行列表,其中包含該 Cookbook。

建立定義

步驟 1 - 在 Cookbook 的 definition 資料夾中建立一個新的定義檔案。

vipin@laptop:~/chef-repo $ subl cookbooks/test_cookbook/definitions/ 
capistrano_deploy_dirs.rb 
define :capistrano_deploy_dirs, :deploy_to => '' do 
   directory "#{params[:deploy_to]}/releases" 
   directory "#{params[:deploy_to]}/shared" 
   directory "#{params[:deploy_to]}/shared/system" 
end

步驟 2 - 在 Cookbook 的預設菜譜中使用定義。

vipin@laptop:~/chef-repo $ subl cookbooks/test_cookbook/recipes/default.rb 
capistrano_deploy_dirs do 
   deploy_to "/srv" 
end 

步驟 3 - 將 Cookbook 上傳到 Chef 伺服器。

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

步驟 4 - 在所需的節點上執行 Chef 客戶端。

vipin@laptop:~/chef-repuser@server $ sudo chef-client 
...TRUNCATED OUTPUT... 
[2013-01-18T16:31:11+00:00] INFO: Processing directory[/srv/ 
releases] action create (my_cookbook::default line 2) 
[2013-01-18T16:31:11+00:00] INFO: directory[/srv/releases] created 
directory /srv/releases 
[2013-01-18T16:31:11+00:00] INFO: Processing directory[/srv/ 
shared] action create (my_cookbook::default line 3) 
[2013-01-18T16:31:11+00:00] INFO: directory[/srv/shared] created 
directory /srv/shared 
[2013-01-18T16:31:11+00:00] INFO: Processing directory[/srv/ 
shared/system] action create (my_cookbook::default line 4) 
[2013-01-18T16:31:11+00:00] INFO: directory[/srv/shared/system] 

Cookbook 中的定義就像微服務一樣,將資源分組併為其命名。定義有一個名稱,可以透過它來識別,可以在菜譜中呼叫,並且它有一組引數。

在定義中,我們有引數,在我們的程式碼中看起來如下所示。

….. 
directory "#{params[:deploy_to]}/releases" 
directory "#{params[:deploy_to]}/shared" 
directory "#{params[:deploy_to]}/shared/system” 
…… 

它可以在預設菜譜中使用,如下所示。

capistrano_deploy_dirs do 
   deploy_to "/srv"` 
end 
廣告

© . All rights reserved.