厨师 - 角色


Chef 中的角色是对节点进行分组的逻辑方式。典型的情况是具有 Web 服务器、数据库服务器等角色。人们可以为所有节点设置自定义运行列表并覆盖角色内的属性值。

创建角色

vipin@laptop:~/chef-repo $ subl roles/web_servers.rb 
name "web_servers" 
description "This role contains nodes, which act as web servers" 
run_list "recipe[ntp]" 
default_attributes 'ntp' => { 
   'ntpdate' => { 
      'disable' => true 
   } 
}

创建角色后,我们需要上传到 Chef 服务器。

将角色上传到 Chef 服务器

vipin@laptop:~/chef-repo $ knife role from file web_servers.rb 

现在,我们需要为名为服务器的节点分配角色。

为节点分配角色

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

运行 Chef 客户端

user@server:~$ sudo chef-client 
...TRUNCATED OUTPUT... 
[2013-07-25T13:28:24+00:00] INFO: Run List is [role[web_servers]] 
[2013-07-25T13:28:24+00:00] INFO: Run List expands to [ntp] 
...TRUNCATED OUTPUT... 

怎么运行的

  • 在 Chef 存储库的 Roles 文件夹内的 Ruby 文件中定义角色。

  • 角色由名称和描述属性组成。

  • 角色由特定于角色的运行列表和特定于角色的属性设置组成。

  • 每个在其运行列表中具有角色的节点都会将该角色的运行列表精确到其自己的运行列表中。

  • 角色运行列表中的所有配方都将在该节点上执行。

  • 将使用 Knife Role from file 命令将该角色上传到 Chef 服务器。

  • 该角色将被添加到节点运行列表中。

  • 在运行列表中具有该角色的节点上运行 Chef 客户端将执行该角色中列出的所有配方。