在短时间不活动后,我在 sidekiq 中出现错误

I get an error in sidekiq after a short time of inactivity

提问人:chelosobaka 提问时间:9/7/2023 更新时间:9/9/2023 访问量:48

问:

我在 sidekiq 中有一份工作,我通过 crontab 运行,现在我通过任何时候都这样做,我也尝试了 sidekiq-cron 和同样的错误。在启动时,一切正常,在一段时间不活动后出现错误。请解释谁知道原因是什么。

Sidekiq 中的错误代码

2023-09-06T23:58:13.292Z pid=345687 tid=76xf ERROR: Error fetching job: Waited 7 seconds
2023-09-06T23:58:13.512Z pid=345687 tid=76xf WARN: {"_config":{"labels":"#<Set: {}>","require":".","environment":"development","concurrency":5,"timeout":25,"poll_interval_average":null,"average_scheduled_poll_interval":5,"on_complex_arguments":"raise","error_handlers":["#<Proc:0x00007faa288f6310 /root/.rbenv/versions/3.1.2/lib/ruby/gems/3.1.0/gems/sidekiq-7.1.2/lib/sidekiq/config.rb:37 (lambda)>"],"death_handlers":[],"lifecycle_events":{"startup":[],"quiet":[],"shutdown":[],"heartbeat":[],"beat":["#<Proc:0x00007faa24b86138 /root/.rbenv/versions/3.1.2/lib/ruby/gems/3.1.0/gems/sidekiq-7.1.2/lib/sidekiq/metrics/tracking.rb:133>"]},"dead_max_jobs":10000,"dead_timeout_in_seconds":15552000,"reloader":"#<Sidekiq::Rails::Reloader @app=OasisVpn::Application>","backtrace_cleaner":"#<Proc:0x00007faa22da5bf0 /root/.rbenv/versions/3.1.2/lib/ruby/gems/3.1.0/gems/sidekiq-7.1.2/lib/sidekiq/rails.rb:59 (lambda)>","queues":["config","send","default"],"config_file":"./config/sidekiq.yml","tag":"rails_oasis-xray","identity":"ruvds-8q2qu:345687:e3cc59408ef3"}}
2023-09-06T23:58:13.512Z pid=345687 tid=76xf WARN: RedisClient::ReadTimeoutError: Waited 7 seconds

配置/initializers/sidekiq.rb

Sidekiq.configure_client do |config|
  config.redis = { url: ENV['REDIS_URL'], size: 10, network_timeout: 5 }
end

Sidekiq.configure_server do |config|
  config.redis = { url: ENV['REDIS_URL'], size: 10, network_timeout: 5 }
end

sidekiq.yml

:queues:
  - config
  - send
  - default

schedule.rb

set :output, {:error => "log/cron_error_log.log", :standard => "log/cron_log.log"}
every 6.hours do
  runner "DeleteConfigsJob.perform_async"
end
Redis Sidekiq Ruby-on-Rails-7

评论


答:

0赞 chelosobaka 9/9/2023 #1

由于服务器较弱且死机,完成工作的时间超过了默认设置的 7 秒。通过增加超时解决了该问题。

:timeout: 25
:queues:
  - config
  - send
  - default