mirror of
https://github.com/hibiken/asynq.git
synced 2025-09-19 13:21:58 +08:00
Add Pause and Unpause methods to rdb
This commit is contained in:
@@ -830,3 +830,33 @@ func (r *RDB) ListWorkers() ([]*base.WorkerInfo, error) {
|
||||
}
|
||||
return workers, nil
|
||||
}
|
||||
|
||||
// KEYS[1] -> asynq:paused
|
||||
// ARGV[1] -> asynq:queues:<qname> - queue to pause
|
||||
var pauseCmd = redis.NewScript(`
|
||||
local ismem = redis.call("SISMEMBER", KEYS[1], ARGV[1])
|
||||
if ismem == 1 then
|
||||
return redis.error_reply("queue is already paused")
|
||||
end
|
||||
return redis.call("SADD", KEYS[1], ARGV[1])`)
|
||||
|
||||
// Pause pauses processing of tasks from the given queue.
|
||||
func (r *RDB) Pause(qname string) error {
|
||||
qkey := base.QueueKey(qname)
|
||||
return pauseCmd.Run(r.client, []string{base.PausedQueues}, qkey).Err()
|
||||
}
|
||||
|
||||
// KEYS[1] -> asynq:paused
|
||||
// ARGV[1] -> asynq:queues:<qname> - queue to unpause
|
||||
var unpauseCmd = redis.NewScript(`
|
||||
local ismem = redis.call("SISMEMBER", KEYS[1], ARGV[1])
|
||||
if ismem == 0 then
|
||||
return redis.error_reply("queue is not paused")
|
||||
end
|
||||
return redis.call("SREM", KEYS[1], ARGV[1])`)
|
||||
|
||||
// Unpause resumes processing of tasks from the given queue.
|
||||
func (r *RDB) Unpause(qname string) error {
|
||||
qkey := base.QueueKey(qname)
|
||||
return unpauseCmd.Run(r.client, []string{base.PausedQueues}, qkey).Err()
|
||||
}
|
||||
|
Reference in New Issue
Block a user