У меня есть следующий фрагмент в рецепте:
template "/mnt/application/config/pusher/#{port}.js" do
owner "root"
group "root"
source "pusher/config.js.erb"
mode "644"
variables({
:directory => metricsDir,
:host => host
})
notifies :run, "bash[restart pusher-#{port}]"
end
bash "restart pusher-#{port}" do
code "supervisorctl restart pusher-#{port}"
action :nothing
end
Проблема в том, что действие bash запускается каждый раз, даже если конфигурация не меняется:
$ cp /mnt/application/config/pusher/50000.js ~/pre-run.js
$ chef-client
...
[Fri, 27 Sep 2013 09:49:03 +0000] INFO: template[/mnt/application/config/pusher/50000.js] sending run action to bash[restart pusher-50000] (delayed)
[Fri, 27 Sep 2013 09:49:03 +0000] INFO: Processing bash[restart pusher-50000] action run (shm::add_pusher line 96)
pusher-50000: stopped
pusher-50000: started
...
$ diff /mnt/application/config/pusher/50000.js ~/pre-run.js
$ echo $?
0
Таким образом, конфиг остался прежним, но действие, тем не менее, было вызвано. Как это исправить?
-l debug
я видел, что владелец меняется. - person Fluffy   schedule 30.09.2013