我有一个 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