我在Rails4应用程序中设置了sidekiq,用于发送电子邮件和处理后台作业。我还设计了我正在使用的devise_async和典型的联系表单电子邮件。我正在使用gmail发送电子邮件。如果我删除sidekiq,它通常会通过gmail(设计和联系表单)发送电子邮件,但是当我启用它时,它不起作用(devise_async和联系表单都没有)。Sidekiq显示后台作业成功启动和完成(我也通过sinatra应用程序看到它们已被处理)但电子邮件从未送达。在开发中,控制台显示已发送电子邮件(使用devise_async和联系表单,因为它们已使用sidekiq成功处理)。我已经尝试过的:我已经为s
我使用Puma作为网络服务器,使用Sidekiq作为我的队列运行器。对于多种事物(数据库连接、Redis连接、其他外部服务),我使用ConnectionPoolgem来管理对连接的安全访问。现在,根据我是在Sidekiq还是Puma的上下文中运行,我需要这些池的大小不同(分别与Sidekiq线程或Puma线程的数量一样大,而且它们是不同的)在您的初始化程序中,根据执行上下文了解连接池大小的最佳方法是什么?谢谢! 最佳答案 您使用Sidekiq.server?当不在Sidekiq进程本身内运行时返回nil。
我有几个这样运行的预定作业:MyWorker.perform_at(3.hours.from_now,'mike',1)我在想,如果稍后,比如说一个小时后,我想取消这份工作,我会怎么做呢? 最佳答案 我最近写了一些代码来处理这个问题,它可以在我的sidekiq-statusgem分支中找到。您可以在此处查看或使用它:https://github.com/Robinson7D/sidekiq-status(目前,您必须将它用作gemfile中的git:信息,直到项目的主分支实现它)要使用它,首先要存储job_identifier:jo
我有这个Sidekiqworker:classDealNoteWorkerincludeSidekiq::Workersidekiq_optionsqueue::emaildefperform(options={})ifoptions[:type]=="deal_watch_mailer"deal_watchers=DealWatcher.where("deal_id=?",options[:deal_id])deal_note=DealNote.find(options[:deal_note_id])current_user=User.find(options[:current_us
我有一个连接到AmazonS3存储桶并下载最新生产备份的ruby脚本。我已经测试了脚本(非常简单)并且工作正常。但是,当我安排此脚本作为cron作业运行时,它似乎在加载Amazon(aws-s3)gem时失败。我的脚本的前几行如下所示:#!/usr/bin/envrubyrequire'aws/s3'正如我所说,当我手动运行此脚本时,它运行良好。当我通过计划的cron作业运行它时,它在尝试加载gem时失败了:`require':nosuchfiletoload--aws/s3(LoadError)此脚本的crontab如下所示:03***~/Downloader/download.
我目前使用延迟作业来异步处理作业。我没有创建worker,而是经常使用.delay方法。我想转到Sidekiq,但是我的工作类型太多,无法确保所有工作都是线程安全的。所以我想并行运行DelayedJob和Sidekiq,并一次迁移一种类型的作业。既然DelayedJob和Sidekiq都提供了.delay方法,那么如何区分两者呢?还有其他潜在问题吗? 最佳答案 对于Sidekiq2.17.1及更高版本,在Rails初始化程序的某处,调用以下命令:Sidekiq.hook_rails!Sidekiq.remove_delay!并且您将
我有一个Rails应用程序,我可以在其中发送大量电子邮件。我想执行此操作异步。为此,我尝试使用Sidekiq,但我无法让它正常工作——它不发送任何电子邮件。发送电子邮件之前有效,所以我确定我的电子邮件设置正确。在我的gemfile中我有这个:gem'sidekiq'我已经运行了bundleinstall。我还安装了redis,按照RailsCasts#366上的说明进行操作.我已经使用以下命令启动了sidekiq:bundleexecsidekiq,结果如下图所示:在application.rb我有以下内容:config.active_job.queue_adapter=:sideki
我正在尝试在开发中使用tail-flog/development.log并在生产中使用herokulogs来记录我的sideqikworker的进度。但是,worker内部的所有内容以及worker调用的所有内容都不会被记录。在下面的代码中,仅记录TEST1。如何记录工作人员内部的所有内容以及工作人员调用的类?#app/controllers/TasksController.rbdefimport_dataRails.logger.info"TEST1"#showsupindevelopment.logDataImportWorker.perform_asyncrender"done"
我目前正在编写一个从RSS源中提取新信息的应用程序,并且必须以一定的频率更新这些RSS源。目前我只在用户请求提要时拉取,但我想将该行为更改为自动定期获取。我正在编写一个与数据库交互并通过cron定期启动的shellscript-但这是很多双重努力,所以我想知道执行此操作的“RailsWay”或“RubyWay”是什么。我正在使用Ubuntu、Apache和Passenger。您能否建议甚至可能包含在应用程序中的更好的方法,这样我就可以轻松地将应用程序部署到另一台机器上,而不必与cron混在一起? 最佳答案 我建议做一些类似rake任
我查看了多个来源并尝试了各种方案,但无法解决这个问题。请指出正确的方向。和每个人一样,我有3个环境(开发、暂存和生产)。我的sidekiq.yml文件中有以下内容#Optionsherecanstillbeoverriddenbycmdlineargs.#sidekiq-Cconfig.yml---:verbose:false:namespace:xyz:logfile:log/sidekiq.log:concurrency:25:strict:false:pidfile:tmp/pids/sidekiq.pid:queues:-[stg_xyz_tests_queue,10]-[st