我目前对后台队列不太满意。我正在尝试让Resque工作。我已经安装了redis和Resquegem。Redis正在运行。一个worker正在运行(rakeresque:workQUEUE=simple)。使用Web界面,我可以看到工作人员正在运行并等待工作。当我运行“rakeget_updates”时,作业已排队但失败了。我已经用defself.perform和defperform试过了。发条.raketask:get_updates=>:environmentdoResque.enqueue(GetUpdates)end类文件(app/workers/get_updates.rb)c
我需要一个用于大型动态任务集合的调度程序。目前我正在查看resque-scheduler,rufus-scheduler,和clockwork.如果您提供有关选择使用哪一个(或其他替代方案)的建议,我将不胜感激。一些细节:有大量要定期执行的任务(最多100K)。最短执行周期为1h。新任务可能会不时出现。现有任务可能会更改或删除。调度延迟最小化在这里不是关键任务(可扩展性和可持续性最重要)。任务执行不是繁重的操作,可以轻松并行。总结,我需要类似cron的Ruby项目,它可以处理大量动态变化的任务集合。更新:我花了一天时间尝试调度库,现在我想简单总结一下新获得的经验。我已经不再关注Cloc
我遵循了https://devcenter.heroku.com/articles/queuing-ruby-resque上的教程在Rails应用程序中排队和运行后台作业。在对作业进行排队后,它似乎没有运行任何作业,因为在控制台中我可以看到作业尚未处理>Resque.info=>{:pending=>1,:processed=>0,:queues=>1,:workers=>0,:working=>0,:failed=>0,:servers=>["redis://dory.redistogo.com:9826/0"],:environment=>"production"}如果我尝试(本地
我知道我们可以做到:sidekiq_optionsqueue:"Foo"但在这种情况下,Worker只分配给一个队列:“Foo”。我需要在特定队列中分配作业(而不是worker)。使用Resque很容易:Resque.enqueue_to(queue_name,my_job)另外,为了并发问题,我需要限制每个队列的Worker数量为1。我该怎么做? 最佳答案 您可能会使用https://github.com/brainopia/sidekiq-limit_fetch然后:Sidekiq::Client.push({'class'=>
我在生产网站上使用Resque。当我部署时,我希望GOD停止所有worker然后重新启动它们,因为有时我们更改类的代码并重新排队失败的作业。问题是,当我执行godstopresque时,rake实际上并没有停止,工作人员仍然活着并使用旧代码,这给我带来了各种各样的问题。即使我“上帝终止”它也不会杀死worker。现在,我正在使用shell脚本来杀死工作人员,但由于我有不止一台服务器,所以在所有生产服务器上进行操作非常痛苦。这是我的上帝配置文件:rails_env=ENV['RAILS_ENV']||"production"rails_root=ENV['RAILS_ROOT']||"/
我正在使用Resque与Redis处理后台作业。我想每小时调用一次方法Resque.enqueue(MyModel)来执行后台任务。例如:假设我有一个拥有10,000名用户的网站。我只想每天调用此方法24次;不是10,000*24。示例方法如下:Resque.enqueue(MyModel)提前感谢您的帮助。我还应该提一下,我更喜欢坚持使用Resque,而不是转向DelayedJob。谢谢。 最佳答案 您应该为此类任务使用cron作业。我建议您使用Whenevergem。在这里查看railscast:http://railscast
我有一个简单的Rails应用程序部署到HerokuCedar堆栈。该应用程序使用Resque并安装了ResqueSinatra前端应用程序,因此我可以监控队列:#routes.rb...mountResque::Server,:at=>"/resque"这很好用,但是当部署到Heroku时,Resquefront-end'sCSS&JavaScript没有被送达。一段Heroku的日志表明它正在返回零字节:...2011-07-13T16:19:35+00:00heroku[router]:GETmyapp.herokuapp.com/resque/style.cssdyno=web.
有没有办法在Resque-workers中将对象作为参数值传递。我想做这样的事情Resque.enqueue(SomeWorker,obj)而不是Resque.enqueue(SomeWorker,id)我的对象是不同类型的没有身份证。感谢任何帮助。 最佳答案 作为最佳实践,您永远不应将真实对象传递给worker。这个想法是您将最少的信息传递给您的工作人员,最好是一个ID,以便工作人员可以自己检索其余信息。由于数据保存在Redis中,您实际上需要在排队时以某种方式编码您的对象,然后在工作人员检索数据时解码它。如果您的对象只是保存一些
我不知道我在这里做了什么,但我试图让Rails中的一个Controller将作业排队到Resque,然后工作人员连接到Resque并完成繁重的工作(即比较、数据库条目)。然而,任务甚至没有运行,因为没有关于设置Resque的明确说明。复制粘贴如下:AlsoavailableinGistformat!这是来自Hoptoad的异常行:NoMethodError:undefinedmethod'perform'forViolateq:Module这是“worker”文件的内容:moduleViolateq@queue=:violateqdefperform(nick,rulenumber)#
我开始在使用NewRelic和resque时遇到奇怪的错误INFO:StartingAgentshutdownERROR:undefinedmethod`write'fornil:NilClass:Unabletosenddatatoparentprocess,pleaseseehttps://newrelic.com/docs/ruby/resque-instrumentationformoreinformation我已按照说明进行操作here我也不再在我的新遗物控制面板中看到任何东西 最佳答案 directions最近已更新。我