草庐IT

resque-delayed

全部标签

ruby - 在 resque scheduler 中调度动态作业

我正在尝试使用rails3和resquescheduler测试future的调度作业:以下是我正在使用的代码,但我收到NoMethodErrorset_schedule。Resque.set_schedule("1",{:cron=>"306**1",:class=>"Notify",:queue=>"username",:message=>'notificationmessage'})我尝试使用简单的入队Resque.enqueue(Notify,params[:message])并且效果很好。更新:以下是我遇到的错误:undefinedmethod`set_schedule'for

ruby-on-rails - 使用 Delayed::Job 管理多个作业队列

我想使用Delayed::Job(或者可能更适合我的问题的作业队列)将作业分派(dispatch)给多个后台守护进程。我有几个执行不同职责的后台守护进程。每个人都对Rails应用程序队列中的不同作业感兴趣。是否可以使用Delayed::Job,或者可能有更适合此任务的不同作业队列? 最佳答案 从那以后http://github.com/collectiveidea/delayed_job已达到v3.0并包括命名队列!非常适合简单的分组队列需求。 关于ruby-on-rails-使用Del

ruby-on-rails - 将 block 传递给 delayed_job

我有一个标记为由delayed_job异步处理的函数:classCapJobsdefexecute(params,id)beginunlessRails.env=="test"Capistrano::CLI.parse(params).execute!endrescuesite=Site.find(id)site.records.create!(:date=>DateTime.now,:action=>"TaskFailure:#{params[0]}",:type=>:failure)site.saveensureyieldidendendhandle_asynchronously:

ruby-on-rails - 如何在 Rails 应用程序中调试 resque 作业

如何在Rails应用程序中调试resque作业?我只想在self.perform函数的日志文件中写入一些信息。这是我写的system("echosos>>/home/maruf/Desktop/log.txt")在self.perform()中。但什么也没发生。什么是正确的方法? 最佳答案 为什么不使用Logger工具?log=Logger.new'log/resque.log'log.debug"foobar"然后tail-f你新生成的日志在"#{Rails.root}/log/resque.log'。记得重启你的resque工作

ruby-on-rails - 使用 rSpec 测试 delayed_job 链的最佳方法是什么?

目前,当我的代码中有一个延迟方法时,如下所示:CommentMailer.delay.deliver_comments(@comment,true)我在规范中写了这样的东西:dj=mock("DelayProxy")CommentMailer.should_receive(:delay).and_return(dj)dj.should_receive(:deliver_comments).with(comment,true)一般来说,有没有更好的方法来处理这个和/或类似rSpec中的链式方法? 最佳答案 我们可以在beforeblo

ruby - 如何阻止上帝留下陈旧的 Resque 工作流程?

我正在尝试了解如何监控travis-ci的resqueworker|与god以这样一种方式停止resquewatchviagod不会留下陈旧的工作进程。在下文中,我谈论的是工作进程,而不是fork作业子进程(即队列一直是空的)。当我像这样手动启动resqueworker时:$QUEUE=buildsrakeresque:work我会得到一个进程:$psx|grepresque7041s001S+0:05.04resque-1.13.0:Waitingforbuilds一旦我停止工作任务,这个过程就会消失。但是当我开始与上帝(exactconfigurationishere,基本上与re

ruby-on-rails - 在 Heroku 上重启后长时间运行的 delayed_job 作业保持锁定状态

当Herokuworker重新启动时(根据命令或作为部署的结果),Heroku将SIGTERM发送到worker进程。对于delayed_job,SIGTERMsignaliscaught然后工作人员在当前作业(如果有)停止后停止执行。如果工作人员需要很长时间才能完成,那么Heroku将发送SIGKILL。在delayed_job的情况下,这会在数据库中留下一个锁定的作业,不会被其他工作人员接收。我想确保作业最终完成(除非出现错误)。鉴于此,解决这个问题的最佳方法是什么?我看到两个选项。但我想获得其他输入:修改delayed_job以在收到SIGTERM时停止处理当前作业(并释放锁定)

ruby-on-rails - Resque multiple workers in development 模式

您好,在开发中可以同时运行多个Resqueworker吗?我找到了这段代码,但不确定它是否会工作以及如何工作..http://pastebin.com/9GKk8GwR到目前为止我使用的是标准bundleexecenvrakeresque:workQUEUE='*'redis-server/usr/local/etc/redis.conf 最佳答案 您需要添加一个COUNT环境变量,然后将resque:work更改为resque:workers。例如启动3个worker:bundleexecenvrakeresque:workers

ruby-on-rails - 如何在 resque-retry 和 Rails 4 中测试重试和失败?

我正在尝试编写一个规范来测试resque-retry的重试功能,但我似乎无法让测试正确命中binding.pry。有没有一种方法可以使用rspec3测试此功能,以便我可以验证它们是否按预期运行?这是一个请求规范,我正在尝试通过固定装置模拟实时请求,但无论我尝试什么,我似乎都无法让作业重试。gem'resque',require:'resque/server'gem'resque-web',require:'resque_web'gem'resque-scheduler'gem'resque-retry'gem'resque-lock-timeout'我正在使用resque_rspec,

ruby - Delayed_job - 多个并行队列?

我正在使用delayed_job并转移到一个更强大的新服务器。所以现在我想运行并行作业,就像现在一样IhavethePOWER!,但对delayed_job是否可以运行多个并行队列感到困惑?Thisquestion建议有命名队列,但这些队列是否都在一个表中运行,因此是顺序的?在底部@JesseWolgamott建议您可以为每个队列创建一个表,然后并行运行。有没有人这样做过,他们能告诉我是怎么做到的吗? 最佳答案 这是可能的,而且我一直在这样做。在我们的例子中,我们需要多个作业来处理三种不同类型的作业,比如queue_a、queue_