Chef - 数据包脚本


在某些情况下,不可能将服务器置于 Chef 的完全控制之下。在这种情况下,人们可能需要从脚本访问 Chef 数据包中的值。为此,需要将数据包值存储在 JSON 文件中,并让添加的脚本访问这些值。

为此,人们需要一本食谱。在我们的例子中,我们将像之前一样使用 test_cookbook,并且应该有节点的运行列表,其中包括 test_cookbook 定义。

工作方式

步骤 1 - 创建数据包。

vipin@laptop:~/chef-repo $ mkdir data_bags/servers 
vipin@laptop:~/chef-repo $ knife data bag create servers 
Created data_bag[servers] 

步骤 2 - 创建数据包项目。

vipin@laptop:~/chef-repo $ subl data_bags/servers/Storage.json { 
   "id": "storage", 
   "host": "10.0.0.12" 
} 

步骤 3 - 更新数据包项目。

vipin@laptop:~/chef-repo $ subl data_bags/servers/Storage.json { 
   "id": "storage", 
   "host": "10.0.0.12" 
} 

在食谱中使用

步骤 1 - 需要使用上述说明书创建一个包含数据包值的 JSON 文件,以便外部脚本可以访问这些值。

vipin@laptop:~/chef-repo $ subl cookbooks/test_cookbook/recipes/default.rb 
file "/etc/backup_config.json" do 
   owner "root"
   group "root" 
   mode 0644 
   content data_bag_item('servers', 'backup')['host'].to_json 
end

步骤 2 - 将 test_cookbook 上传到 Chef 服务器。

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

步骤 3 - 在节点上运行 Chef 客户端。

user@server:~$ sudo chef-client 
...TRUNCATED OUTPUT... 
[2013-03-14T20:30:33+00:00] INFO: Processing 
file[/etc/backup_config.json] action create 
(my_cookbook::default line 9) 
[2013-03-14T20:30:34+00:00] INFO: entered create 
[2013-03-14T20:30:34+00:00] INFO: 
file[/etc/backup_config.json] owner changed to 0 
[2013-03-14T20:30:34+00:00] INFO: 
file[/etc/backup_config.json] group changed to 0 
[2013-03-14T20:30:34+00:00] INFO: 
file[/etc/backup_config.json] mode changed to 644 
[2013-03-14T20:30:34+00:00] INFO: 
file[/etc/backup_config.json] created file 
/etc/backup_config.json 
...TRUNCATED OUTPUT... 

步骤 4 - 验证生成的 JSON 文件的内容。

user@server:~$ cat /etc/backup_config.json 
"10.0.0.12" 

脚本的工作流程

在上面的命令中,我们使用的在/etc目录中创建 JSON 文件的文件资源是在默认说明书中定义的。它使用 data_bag_item 方法直接从数据包中获取文件内容。我们从数据包项中访问主机值并将其转换为 JSON。文件资源使用 JSON 转换后的值作为其内容并将其写入磁盘。