-
-
Notifications
You must be signed in to change notification settings - Fork 276
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Unexpected behavior with until_executed #250
Comments
This sounds like the same thing I ran into today. @mwpastore, were you able to find a workaround? |
Unfortunately, not really. I switched to using a watchdog thread for these long-running jobs that manually looks to see if the job is running, queued, or pending retry, and starts it if not. # frozen_string_literal: true
require_relative 'worker_classes'
WATCHED_WORKER_CLASSES = [WatchMailboxWorker, WatchSubsWorker].freeze
default = Sidekiq::Queue.new
workers = Sidekiq::Workers.new
retry_set = Sidekiq::RetrySet.new
Thread.new do
sleep 60
WATCHED_WORKER_CLASSES.each do |worker_class|
# Is job queued?
next if default.map(&:klass)
.include?(worker_class.name)
# Is job running?
next if workers.map { |*, work| work['payload']['class'] }
.include?(worker_class.name)
# Is job pending an automatic retry?
next if retry_set.map(&:klass)
.include?(worker_class.name)
worker_class.perform_async
end
redo
end |
The |
I agree that the 30 minute timeout is unexpected, and it was hard to discover. Defaulting to never expiring would be better, in my opinion. |
I will take care of this for the next major version and add a note about this in the readme's. |
Version 6 won't have this problem and it will take care of the upgrade automatically. Keep an eye out on the README and CHANGELOG for more information about the changes. |
I have some long-running (infinite loop) jobs that are
:unique=>:until_executed
. The README says, "By default the lock doesn't expire at all," and it specifically calls out only:while_executing
and:until_and_while_executing
(i.e. not:until_executed
) as locking modes. However, when I start this job, I notice that itsuniquejobs:{digest}
key takes a TTL of 1800. After 1,800 seconds, if a process attempts to queue one of these jobs (while the original instance is still running), it will launch a duplicate job. I tried adding:lock_expiration=>nil
to address this issue, but the behavior persists.nil
)?uniquejobs:{digest}
key, or is that a bug (i.e. it should be settable tonil
)?The text was updated successfully, but these errors were encountered: