📅  最后修改于: 2020-11-02 03:25:37             🧑  作者: Mango
定义可以定义为对资源进行分组的逻辑方法,这些方法可以一次又一次地使用。在此流程中,我们对资源进行分组并为其命名,以重新获得已定义食谱的可读性。
为了做到这一点,我们应该有一个食谱。在这种情况下,我们使用test_cookbook和节点的运行列表,其中包括菜谱。
步骤1-在cookbooks定义文件夹中创建一个新的定义文件。
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-在食谱默认食谱中使用定义。
vipin@laptop:~/chef-repo $ subl cookbooks/test_cookbook/recipes/default.rb
capistrano_deploy_dirs do
deploy_to "/srv"
end
步骤3-将食谱上载到厨师服务器。
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]
食谱中的定义就像Micros,将资源分组并给它们命名。定义具有一个名称,通过该名称可以告诉他们可以在配方内部进行调用的名称,并且具有周长列表。
在定义中,我们有一些参数,这些参数在我们的代码中如下所示。
…..
directory "#{params[:deploy_to]}/releases"
directory "#{params[:deploy_to]}/shared"
directory "#{params[:deploy_to]}/shared/system”
……
可以在默认配方中使用它,如下所示。
capistrano_deploy_dirs do
deploy_to "/srv"`
end