如何在 Rails 中的 Redis 和 SideKiq 中顺序处理队列?

How to process queue sequentially in Redis and SideKiq in Rails?

我在我的应用程序中使用 Rails 4,这就是我创建新工作的方式:

class FetchJob < ActiveJob::Base
  queue_as :fetchjob
  def perform num
    puts num
    sleep 30
  end
end

此代码打印出 num 的值,然后休眠 30 秒。我正在使用 sidekiq gem 和 redis 来处理这个队列。我在创建用户后对作业进行排队。

class FecthJobController < ApplicationController
  def create
    @user = User.create(user_params)
    FetchJob.perform_later(@user.id)
  end

  private
  def user_params
    ....
  end
end

队列中的作业正在并行执行。队列中的作业是指 job1、job2、job3、job4 等。那么我怎么可能按顺序执行这些作业。即只有当 job1 完成时,它才会处理 job2,然后是 job3,依此类推。如何在sidekiq中锁定它直到作业完成?

您可能会发现一个 hack 可以让您做您想做的事,但让我提出一些其他建议:您使用了错误的工具。 Sidekiq 并非设计为以这种方式运行。

https://github.com/mperham/sidekiq/wiki/Best-Practices#3-embrace-concurrency