2

我有一个 Sidekiq 工作人员,它将 Rails 3.2 应用程序的数据与远程数据库同步。当我从 Rails 控制台执行它时,一切都按预期工作。我可以验证它是否连接到远程数据库并提取我期望的数据。

我尝试设置以下内容的那一刻:

recurrence {daily.hour_of_day(20).minute_of_hour(02)}

我在 Sidekiq 中看到以下内容,但没有完成/执行的迹象:

2014-05-14T00:02:18Z 6747 TID-dvc2c INFO: [Sidetiq] Enqueue: BackendWorker (at: 1400112120.0) (last: -1.0)

我目前已将重试设置为 false(我想更改),并且我试图在再次设置另一个测试运行之前清除 redis 中的任何内容。

有没有办法挤压更多关于正在发生的事情的信息?我可以使用 Sidekiq 标志来获取一些额外的调试信息吗?

提前致谢

环境:

  • 导轨 3.2
  • 红宝石 2.1
  • Sidetiq 0.5.0
  • Sidekiq 2.17.7(由于使用 3.0 的问题)

更新(2014 年 5 月 14 日):

我决定用 Sidetiq 测试一个简单的例子,并且只有一个用 ActiveRecord 创建数据库条目的工作人员:

class BackendTest
  include Sidekiq::Worker
  include Sidetiq::Schedulable
  sidekiq_options :retry => false, :backtrace => true

  recurrence {
    daily.hour_of_day(11).minute_of_hour(05)
  }

  def perform
    Book.create(title: "test", author: "testing", price: 9.99)
  end
end

我做的另一个实验只是试图让 Sidetiq 和 Sidekiq 用 logger.info 显示一些东西:

class BackendTest
  include Sidekiq::Worker
  include Sidetiq::Schedulable
  sidekiq_options :retry => false, :backtrace => true

  recurrence {
    daily.hour_of_day(16).minute_of_hour(00)
  }

  def perform
    logger.info "test"
    logger.info "test"
  end
end

作业仍会进入默认队列而未启动或完成。perform_async如果我只是使用, 从 Rails 控制台启动它,一切仍然有效Sidekiq::Client.push,并且Sidekiq::Client.enqueue仍然可以从控制台工作。

在这一点上,我是一个完全困惑的新手。

输出:

2014-05-14T20:08:41Z 2149 TID-dfcfk BackendTest JID-6bc7ba08955f8340903f9063 INFO: start 2014-05-14T20:08:41Z 2149 TID-dfcfk BackendTest JID-6bc7ba08955f8340903f9063 INFO: test 2014-05-14T20:08:41Z 2149 TID-dfcfk BackendTest JID-6bc7ba08955f8340903f9063 INFO: test 2014-05-14T20:08:41Z 2149 TID-dfcfk BackendTest JID-6bc7ba08955f8340903f9063 INFO: done: 0.002 sec

4

1 回答 1

2

在 github 上浏览了其他人的项目后,我看到了一些有趣的东西并尝试了一下,它似乎解决了我使用 Sidetiq 的问题。

我在其中创建/config/initializers/sidekiq.rb了以下内容:

Sidekiq.configure_server do |config|
  config.redis = { :url => 'redis://localhost:6379/3', :namespace => 'sidekiq' }
end

Sidekiq.configure_client do |config|
  config.redis = { :url => 'redis://localhost:6379/3', :namespace => 'sidekiq' }
end

作业任务按预期排队并执行。

于 2014-05-16T17:56:50.563 回答