我正在使用delayed_job并转移到一个更强大的新服务器。所以现在我想运行并行作业,就像现在一样IhavethePOWER!,但对delayed_job是否可以运行多个并行队列感到困惑?Thisquestion建议有命名队列,但这些队列是否都在一个表中运行,因此是顺序的?在底部@JesseWolgamott建议您可以为每个队列创建一个表,然后并行运行。有没有人这样做过,他们能告诉我是怎么做到的吗? 最佳答案 这是可能的,而且我一直在这样做。在我们的例子中,我们需要多个作业来处理三种不同类型的作业,比如queue_a、queue_
我有一个使用delayed_job运行的后台任务。我可以看到它确实从日志语句运行。与在前台运行相比,它似乎没有正确的结果,所以我想在IRB控制台中调试它。我正在运行后台任务rakejobs:work并且它不会触发调试器语句。如何加载调试器? 最佳答案 启动一个标准的rails控制台rubyscript/console并在此处启动一个worker,这将看到并触发调试器语句。worker=Delayed::Worker.newworker.start 关于ruby-on-rails-如何调试
我正在安排一项工作,比如在10分钟内运行。如何在不使用模型中任何类型的肮脏额外字段等的情况下正确取消此特定作业。是否有删除特定作业或与特定模型、实例等相关的作业的调用? 最佳答案 免责声明:我不是delayed_job的专家用户...“是否有删除特定作业或与特定模型、实例等相关的作业的调用?”Delayed::Job只是一个ActiveRecord对象,因此您可以找到并销毁任何这些记录。根据您的用例,这可以用不同的方式处理。如果有人要手动销毁它们,这可以通过您的网络应用程序中的管理界面来处理。#listalljobsDelayed:
我无法从delayed_job获得任何日志输出,而且我不确定我的作业是否开始。这是我的Procfile:web:bundleexecrailsserverworker:bundleexecrakejobs:workworker:bundleexecclockworkapp/clock.rb这是工作:classScanningJobdefperformlogger.info"loggingfromdelayed_job"enddefafter(job)Rails.logger.info"loggingfromafterdelayed_job"endend我看到发条输出到系统输出,我可以看
Delayed::Job的自动重试功能很棒,但现在有一个作业我想手动重试。有没有一种方法我可以调用工作本身,比如...Delayed::Job.all[0].perform或者跑,或者什么的。我尝试了一些东西,并梳理了文档,但无法弄清楚如何执行作业的手动重试。 最佳答案 手动调用作业Delayed::Job.find(10).invoke_job#10isthejob.id如果成功运行,这不会删除作业。您需要手动将其删除:Delayed::Job.find(10).destroy 关于r
网络上是否有关于如何使用Monit监控delayed_job的示例??我能找到的所有东西都使用God,但我拒绝使用上帝,因为在Ruby中长时间运行的进程通常很糟糕。(上帝邮件列表中的最新帖子?GodMemoryUsageGrowsSteadily。)更新:delayed_job现在带有samplemonitconfig基于这个问题。 最佳答案 下面是我如何让它工作的。使用collectiveideaforkofdelayed_job除了积极维护之外,这个版本还有一个不错的script/delayed_job可以与monit一起使用的
当我在app.conf中启用module.jobs时出现以下错误尝试重新下载模块包。在cron包中提供。没有用。INFO2017/05/0118:51:12main.go:32:Runningrevelserverpanic:reflect:callofreflect.Value.TypeonzeroValuegoroutine1[running]:panic(0xbd1b00,0xc4201e7c20)/usr/local/go/src/runtime/panic.go:500+0x1a1reflect.Value.Type(0x0,0x0,0x0,0x0,0x0)/usr/loca
我一直在用时区的cron作业做一些测试。我的目标是为每个时区设置1个cron作业,以便它可以独立于服务器位置运行。packagemainimport("fmt""github.com/robfig/cron""os""os/signal""time")funchelloWorld(){fmt.Println("helloworld")}funcmain(){s,err1:=cron.Parse("2615***")fmt.Println(err1)l,err:=time.LoadLocation("Asia/Tokyo")fmt.Println(err)c:=cron.NewWithL
我想向SplunkRESTAPI发送搜索/查询,并返回搜索ID以供稍后使用结果。我可以通过以下curl实现所需的行为:#!/bin/bashuser='my_user'pass='my_pass'search='searchindex=shortsourcetype=src|head5'curl-u$user:$pass-khttps://111.22.33.44:8089/services/search/jobs-dsearch="$search"返回:234523452435.6556_234234-3J3J-34J4-2345-123456678E3以下是我试图在其中实现相同目标
我正在尝试打开第二个批处理文件并检测它是否正常退出或由用户关闭(ctrl+c或x或窗口终止等。)所以我使用以下示例Batchrunscriptwhenclosed@Echooffseterrorlevel=1start/w%comspec%/c"mode70,10&titleFolderConfirmationBox&color1e&echo.&echo.Elsetheclosewindow&pause>NUL&exit12345"echo%errorlevel%pause我试图让第一个批处理等待(/W),因为我稍后会检查错误级别但是在关闭第二个批处理文件后,我得到了一个错误,比如^c