了解 Redis、Sidekiq、Heroku 和 Rails 5 的后台工作者

Understanding Background Workers with Redis, Sidekiq, Heroku and Rails 5

我有一个 Rails 5 应用程序,我开始使用 Sidekiq、Heroku 和 Redis 将各种作业转移到后台。

到目前为止,我有 ResetFinanceDataWorker,它有一个 Class 同名。

//reset_finance_data_worker.rb

class ResetFinanceDataWorker
  include Sidekiq::Worker
  sidekiq_options retry: false

  def perform()
  end
end

我可以通过调用 ResetFinanceDataWorker.perform_in(10.seconds) 来调用它。理想情况下,我希望在一个文件中有多个工作人员,如下所示:

//finance_worker.rb

class AnotherWorker
  include Sidekiq::Worker
  sidekiq_options retry: false

  def perform()
  end
end

class ResetFinanceDataWorker
  include Sidekiq::Worker
  sidekiq_options retry: false

  def perform()
  end
end

并且能够调用 FinanceWorker.AnotherWorker.perform_in(10.seconds)。然而,这是不可能的。

谁能给我解释一下 1) 我将如何完成这项工作?和 2) 组织工作文件的最佳实践。

谢谢。

最佳做法和惯例是在一个文件中只放置一个 class 并具有相应的文件名。不管是 worker 还是任何其他 class。如果你想整理它们,你可以将类似的工人包装在一个模块中,然后将它们移动到一个单独的文件夹中 finance_worker:

 module FinanceWorker  
   class AnotherWorker
   end
 end

在这种情况下,您可以调用 FinanceWorker::AnotherWorker.perform_async

更新:

app/jobs 中创建一个单独的文件夹 finance_worker 并将所有需要的工作文件移到那里。将所有这些工人 classes 包装在 module FinanceWorker 中。我的意思是,分开包装,仍然在不同的文件中,仍然 only one class, wrapped in module, inside the file.

如果您有 10 个工人,您有 10 个文件。但它是 Sidekiq workers,不是 heroku workers,不要混淆。要启动 Sidekiq,您只需要 Procfile 中的一行:worker: bundle exec sidekiq。该行将为 Sidekiq 启动 1 个 heroku worker dyno,这将启动他的所有 10 个 worker。没关系,这是常见的做法。如果您注意到 Sidekiq 的 1 个 dyno 不够,您总是可以添加更多,它们会在彼此之间划分队列。

并且不要忘记您可以为工作人员指定队列名称。默认情况下,所有作业都进入常规 default 队列。如果您希望工人有自己的队列,只需添加 sidekiq_options:

sidekiq_options retry: false, queue: 'finance'