ruby-on-rails - Sidekiq - 间歇性不启动

标签 ruby-on-rails redis sidekiq

我正在处理一个令人沮丧的错误 - 有时 sidekiq 不会开始处理作业。这是烦人的间歇性。

发生这种情况时,sidekiq.log 没有显示任何变化(并且正在运行)。队列大小保持为 0。我猜它在 Redis 中丢失了。

以防万一,我在同一台机器上运行了同一应用程序的三个环境(不同的环境),这是我刚刚放入的(但问题先于它们)。只有一个 Redis 在默认端口上运行。

我知道 redis-cli MONITOR 但它吐出的东西太快了,而且太多了,我很难弄清楚发生了什么。

1491479154.190069 [0 127.0.0.1:38763] "brpop" "queue:default" "2"
1491479154.289507 [0 127.0.0.1:38753] "brpop" "queue:default" "2"
1491479154.289544 [0 127.0.0.1:38752] "brpop" "queue:default" "2"
/// snip... many lines of these
1491479154.364985 [0 127.0.0.1:38772] "multi"
1491479154.365090 [0 127.0.0.1:38772] "incrby" "stat:processed" "0"
1491479154.365107 [0 127.0.0.1:38772] "incrby" "stat:processed:2017-04-06" "0"
1491479154.365128 [0 127.0.0.1:38772] "incrby" "stat:failed" "0"
1491479154.365133 [0 127.0.0.1:38772] "incrby" "stat:failed:2017-04-06" "0"
1491479154.365139 [0 127.0.0.1:38772] "del" "server.name:32533:6befea0f66c0:workers"
1491479154.365149 [0 127.0.0.1:38772] "expire" "server.name:32533:6befea0f66c0:workers" "60"
1491479154.365160 [0 127.0.0.1:38772] "exec"
1491479154.365896 [0 127.0.0.1:38772] "multi"
1491479154.365962 [0 127.0.0.1:38772] "sadd" "processes" "server.name:32533:6befea0f66c0"
1491479154.365977 [0 127.0.0.1:38772] "exists" "server.name:32533:6befea0f66c0"
1491479154.365987 [0 127.0.0.1:38772] "hmset" "server.name:32533:6befea0f66c0" "info" "{\"hostname\":\"server.name\",\"started_at\":1491373877.8700902,\"pid\":2217,\"tag\":\"demo\",\"concurrency\":25,\"queues\":[\"default\"],\"labels\":[],\"identity\":\"server.name:32533:6befea0f66c0\"}" "busy" "0" "beat" "1491479154.3655496" "quiet" "false"
1491479154.366035 [0 127.0.0.1:38772] "expire" "server.name:32533:6befea0f66c0" "60"
1491479154.366046 [0 127.0.0.1:38772] "rpop" "server.name:32533:6befea0f66c0-signals"
1491479154.366058 [0 127.0.0.1:38772] "exec"
1491479154.389484 [0 127.0.0.1:38751] "brpop" "queue:default" "2"

如何调试 Redis 和 Sidekiq 来解决这个问题?我想用 grep 进行管道传输,但我不能在 redis-cli 交互式 shell 中执行...

想法?

最佳答案

有两个运行不同环境的实例。一旦我删除了分期,生产工作就很好了。我猜它没有正确设置。

关于ruby-on-rails - Sidekiq - 间歇性不启动,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/43254398/

相关文章:

ruby - perform_async 在 sidekiq 中不起作用

ruby-on-rails - 如何分离开发和生产 sidekiq 工作人员

ruby-on-rails - Rails 3.1,工厂女孩错误

ruby-on-rails - 嵌套属性上的重复条目具有良好的曝光度

ruby-on-rails - rails 控制台要求 nokogiri 返回 false(但在 irb 中工作)

sorting - 使用集合中的哈希对redis中的集合进行排序

django - 导入 asgi_redis : ImportError: No module named _compat

ruby-on-rails - 如何使用 Rails XML Builder 创建单个元素 JSON 数组?

Redis 瞬间崩溃无报错

ruby-on-rails - SidekiqVS。兔子MQ