ruby – 仅在特定服务器上调用delayed_job capistrano任务

我有一个用于delayed_job任务的专用服务器.我想只在这台服务器上启动,停止和重启delayed_job worker.我正在使用delayed_job提供的capistrano食谱.

当我只有1台服务器时,这是我的配置:

before "deploy:restart","delayed_job:stop"
after  "deploy:restart","delayed_job:start"

after "deploy:stop","delayed_job:stop"
after "deploy:start","delayed_job:start"

现在我想让这些钩子只适用于一个单独的delayed_job服务器(角色:delayed_job< ip address>).这可能优雅吗?我是否必须在meta任务中包装每个delayed_job任务?或者写我自己的任务而不是使用延迟工作提供的任务?

解决方法

在Capistrano中定义任务时,可以将任务的执行限制为特定角色.执行此操作的方法是传递:role选项.

似乎default delayed_job Capistrano recipe就是这样做的.

desc "Stop the delayed_job process"
task :stop,:roles => lambda { roles } do
  run "cd #{current_path};#{rails_env} script/delayed_job stop"
end

根据源代码,任务从:delayed_job_server_role配置变量中获取角色列表.

回到您的问题,将任务的执行范围缩小到特定的服务器组,在deploy.rb中定义一个新角色(例如worker)

role :worker,"192.168.1.1" # Assign the IP of your machine

然后将:delayed_job_server_role设置为该名称

set :delayed_job_server_role,:worker

就这样.现在,任务将被执行,但仅限于:worker角色中列出的服务器.

相关文章

validates:conclusion,:presence=>true,:inclusion=>{...
一、redis集群搭建redis3.0以前,提供了Sentinel工具来监控各...
分享一下我老师大神的人工智能教程。零基础!通俗易懂!风趣...
上一篇博文 ruby传参之引用类型 里边定义了一个方法名 mo...
一编程与编程语言 什么是编程语言? 能够被计算机所识别的表...
Ruby类和对象Ruby是一种完美的面向对象编程语言。面向对象编...