我正在使用Sidekiq对于我的后台工作:我有一个workerapp/workers/data_import_worker.rbclassDataImportWorkerincludeSidekiq::Workersidekiq_optionsretry:falsedefperform(job_id,file_name)begin#Somelogicinit.....endend从文件lib/parse_excel.rb调用defparse_raw_data#job_idand#filenamearedefinedbfrDataImportWorker.perform_async(jo
重启sidekiq的正确方法是什么。它似乎在我启动它时缓存了我的worker代码,所以每次我对我的worker进行更改时我都需要重新启动它。我正在使用Ctrl/C执行此操作,但该过程需要很长时间才能结束并返回到提示符。有没有办法立即强制重启?我使用的是通过POW运行的Sinatra的最新版本。 最佳答案 Sidekiq自带命令sidekiqctl,可以停止与你的Sidekiq进程关联的PID。您传入PID文件和等待所有线程完成的秒数。示例用法:sidekiqctlstop#{rails_root}/tmp/pids/sidekiq_
我的ruby在/usr/local/bin中。whenever找不到它,并且在我的cron文件顶部设置PATH也不起作用,我认为是因为无论何时在新的bash实例中运行命令。#thisdoesnotworkPATH=/bin:/sbin:/usr/bin:/usr/sbin:/usr/local/sbin#BeginWhenevergeneratedtasksfor:foo0****/bin/bash-l-c'cd/srv/foo/releases/20110429110637&&script/railsrunner-eproduction'\''ActiveRecord::Sessio
我有一个包含大量任务的应用程序,每天我都想运行一个cron作业,为数据库中的每个任务创建一个DayTask。一个Task有_manyDayTasks,这些daytasks是用户每天要检查的内容。我正在使用whenevergem,但它似乎根本没有运行。有什么想法吗?配置/schedule.rbevery1.day,:at=>"12:01am"dorunner"Task.generate_tasks_for_day"end任务.rbdefgenerate_tasks_for_dayTask.all.eachdo|task|task.day_tasks.create(:target_date
我正在使用Sidekiqworker在用户首次登录后完成对Facebook的一些请求。通常该任务大约需要20秒左右。我想在同步完成后立即使用ajax请求将一些信息加载到页面上,但不确定使用Javascript检查作业完成情况的最佳方式。一种可能性是配置Sidekiqworker在完成其余工作后设置cookie。然后我可以使用setTimeout函数在调用加载函数之前继续检查cookie。但我不确定这是否是最好的方法。我可以改用Redis吗? 最佳答案 Paul,最初你必须看一下这个PubSubonRailstutorial!当异步事
如何在Ubuntu上将sidekiq作为守护进程运行?如果我运行bundleexecsidekiq-D我得到invalidoption:-D,有没有办法在没有其他Controller的情况下运行它,比如god,upstart。..? 最佳答案 Daemonizesidekiq有一个选项,只需传递-d选项commit 关于ruby-on-rails-在Ubuntu上将Sidekiq作为守护进程运行,我们在StackOverflow上找到一个类似的问题: http
在我的一个项目中,我正在使用Sidekiq是否有任何内置的Sidekiq控制台方法/方法可以帮助我确定sidekiq是否正在运行。我的要求是一种预检查条件,如果Sidekiq未运行,我将引发错误。我试过像这样使用grep'ps-ef|grepsidekiq'但这并没有解决我的目的。我正在寻找的方法应该是这样的:Sidekiq.is_running?提前致谢。我也试过Sidekiq未运行1.9.3p392:021>system'psaux|grepsidekiq'ankitgupta66830.00.02432768600s001R+11:47AM0:00.00grepsidekiqan
我不熟悉Sidekiq的内部结构,想知道是否可以启动多个具有相同配置(处理相同队列)的Sidekiq实例。是否有可能2个或更多Sidekiq实例将处理来自队列的相同消息?更新:我需要知道在超过1台机器上运行Sidekiq时是否可能存在冲突 最佳答案 是的,sidekiq绝对可以针对同一个队列运行多个进程。Redis只会将消息交给随机进程。 关于ruby-多个sidekiq实例可以处理同一个队列吗,我们在StackOverflow上找到一个类似的问题: http
我正在使用sidekiqgem在后台运行API调用。我在Daemon进程中运行了sidekiq,如下所示:bundleexecsidekiq-d现在我对我的方法做了一些改变,所以我想重启sidekiq。我尝试使用以下命令杀死sidekiq:kill-9process_id但它不起作用。我想知道重新启动sidekiq进程的命令。如果您有任何想法,请与我分享。我也试过下面的命令:sidekiqctlstop/path/to/pidfile/pids/sidekiq.pid 最佳答案 开始:$bundleexecsidekiq-d-Ptm
有谁知道如何找到sidekiq的pid文件来优雅地关闭它?正在运行psax|grepsidekiq然后运行sidekiqctlstop始终给出nosuchpidfile错误?Cntl-C和Cntl-D似乎也没有效果。关闭进程窗口并重新打开一个新窗口并不会终止进程,因为它似乎正在作为守护进程运行。我发现的唯一一致的修复方法是重新启动。 最佳答案 用它来强行杀死sidekiq。ps-ef|grepsidekiq|grep-vgrep|awk'{print$2}'|xargskill-9