FIX: signaling seems flaky, simply kill thread

This commit is contained in:
Sam 2014-08-19 14:59:40 +10:00
parent cb686792df
commit 997ab7a770
1 changed files with 6 additions and 18 deletions

View File

@ -3,7 +3,6 @@ require 'thread'
class SidekiqPauser class SidekiqPauser
def initialize def initialize
@mutex = Mutex.new @mutex = Mutex.new
@done = ConditionVariable.new
end end
def pause! def pause!
@ -21,19 +20,12 @@ class SidekiqPauser
end end
def unpause! def unpause!
# concurrency is hard, perform signaling from a bg thread
# otherwise it acts weird
Thread.new do
@mutex.synchronize do
if @pause_thread
@paused = false
@done.signal
end
end
end.join
@mutex.synchronize do @mutex.synchronize do
@pause_thread.join if @pause_thread if @pause_thread
@paused = false
end
@pause_thread.kill
@pause_thread.join
@pause_thread = nil @pause_thread = nil
end end
@ -50,11 +42,7 @@ class SidekiqPauser
Sidekiq.redis do |r| Sidekiq.redis do |r|
r.setex paused_key, 60, "paused" r.setex paused_key, 60, "paused"
end end
sleep 30
@mutex.synchronize do
return unless @paused
@done.wait(@mutex, 30)
end
end end
end end
end end