我正在使用Chef安装serf,然后我需要执行serf members -format=JSON。我的代码如下所示:
include_recipe "mycookbook::serf"
log `serf members -format=json`但是,没有任何内容打印到日志中。重新运行chef run (在安装serf之后)会在日志中生成JSON输出。
为什么它不能在第一时间得到信息?我们如何确保程序在调用serf members之前已安装
发布于 2014-02-08 02:00:02
准确地找出代码在Chef中进行评估的时间可能有点棘手。这是一个多通道的过程。First chef评估其运行列表中的所有食谱,以建立一个要做的事情的列表。如果你写的是"raw ruby“,它会在这个阶段被计算。
因此,在您的示例中,当您使用shell运行serf二进制文件时,它还不可用。
有几种方法可以处理这个问题,最简单的方法是在chef运行结束时将serf命令放在报告处理程序中。
http://docs.opscode.com/handlers.html
如果在运行期间需要serf结果,则需要指定运行serf命令依赖于资源。要做到这一点,最简单的方法是将serf命令放在ruby_block资源中。
http://docs.opscode.com/resource_ruby_block.html
这确保了ruby将在初始遍历和serf安装cookbook之后执行。
发布于 2014-02-08 03:28:11
你想把它放在一个ruby_block中
include_recipe "mycookbook::serf"
ruby_block do
block do
Chef::Log.info `serf members -format=json`
end
endhttps://stackoverflow.com/questions/21633963
复制相似问题