Rails 6 应用程序如何将 Sidekiq+Redis 用于 Hotwire/Stimulus,而将 DelayedJob 用于“工人工作”,例如电子邮件

Posted

技术标签:

【中文标题】Rails 6 应用程序如何将 Sidekiq+Redis 用于 Hotwire/Stimulus,而将 DelayedJob 用于“工人工作”,例如电子邮件【英文标题】:How can a Rails 6 app use Sidekiq+Redis for Hotwire/Stimulus but DelayedJob for "worker jobs" such as emails 【发布时间】:2021-08-17 17:01:52 【问题描述】:

对于我们所有的 Rails 应用程序,我们将 DelayedJob 用于“关键工作作业”(发送电子邮件等),因为对于这些作业,我们希望在我们的主要 postgres 数据库存储中进行作业,以简化管理员检查、查询、调试、持久性和如果/需要时手动重试。对于这些类型的作业,DelayedJob 具有足够的性能。

但我们也想开始使用 Hotwire,据我了解,它需要 ActionCable,它需要 ActiveJobs,并且受益于内存中 Sidekiq+Redis 提供的额外作业处理速度,不需要持久性和幂等性。

有什么方法可以将 ActiveJob 用作基于 DelayedJob 的工作作业和基于 Sidekiq 的 ActionCable 作业的作业系统?

或者将 Sidekiq 用于 Hotwire/ActionCable要求我们基于 DelayedJob 的工作人员作业放弃使用 ActiveJob(因此使用本机 DelayedJob 作业)?

【问题讨论】:

【参考方案1】:

You can have several jobs backends.

 class HotwireActionCableJob < ApplicationJob
   self.queue_adapter = :sidekiq
   # broadcast/stream something through action cable 
 end

 class SomeOtherJob < ApplicationJob
   self.queue_adapter = :delayed_job
 end

或者将 Sidekiq 用于 Hotwire/ActionCable 是否需要我们的 使用 ActiveJob 放弃基于 DelayedJob 的工作程序(因此 使用本机 DelayedJob 作业)?

我认为您可以在所有事情中使用 ActiveJob,只需在作业类中指定适配器。

【讨论】:

以上是关于Rails 6 应用程序如何将 Sidekiq+Redis 用于 Hotwire/Stimulus,而将 DelayedJob 用于“工人工作”,例如电子邮件的主要内容,如果未能解决你的问题,请参考以下文章

如何使用 Sidekiq 在 Rails 中 3 分钟后发送电子邮件?

Rails 6主动存储sidekiq文件在S3上上传背景图片

Rails:如何重启sidekiq?

在多线程 Rails 环境中使用 Redis 的最佳方式是啥? (彪马/Sidekiq)

Docker-compose 与 redis、sidekiq、rails SocketError

Sidekiq Rails 4.2使用活动作业还是工作者?有什么不同