mirror of
				https://github.com/hibiken/asynq.git
				synced 2025-10-26 11:16:12 +08:00 
			
		
		
		
	Add redis pubsub subscriber for cancelation
This commit is contained in:
		| @@ -6,6 +6,7 @@ | ||||
| package base | ||||
|  | ||||
| import ( | ||||
| 	"context" | ||||
| 	"fmt" | ||||
| 	"strings" | ||||
| 	"sync" | ||||
| @@ -30,6 +31,7 @@ const ( | ||||
| 	RetryQueue      = "asynq:retry"                  // ZSET | ||||
| 	DeadQueue       = "asynq:dead"                   // ZSET | ||||
| 	InProgressQueue = "asynq:in_progress"            // LIST | ||||
| 	CancelChannel   = "asynq:cancel"                 // PubSub channel | ||||
| ) | ||||
|  | ||||
| // QueueKey returns a redis key string for the given queue name. | ||||
| @@ -129,3 +131,50 @@ func (p *ProcessInfo) IncrActiveWorkerCount(delta int) { | ||||
| 	defer p.mu.Unlock() | ||||
| 	p.ActiveWorkerCount += delta | ||||
| } | ||||
|  | ||||
| // Cancelations hold cancel functions for all in-progress tasks. | ||||
| // | ||||
| // Its methods are safe to be used in multiple concurrent goroutines | ||||
| type Cancelations struct { | ||||
| 	mu          sync.Mutex | ||||
| 	cancelFuncs map[string]context.CancelFunc | ||||
| } | ||||
|  | ||||
| // NewCancelations returns a Cancelations instance. | ||||
| func NewCancelations() *Cancelations { | ||||
| 	return &Cancelations{ | ||||
| 		cancelFuncs: make(map[string]context.CancelFunc), | ||||
| 	} | ||||
| } | ||||
|  | ||||
| // Add adds a new cancel func to the set. | ||||
| func (c *Cancelations) Add(id string, fn context.CancelFunc) { | ||||
| 	c.mu.Lock() | ||||
| 	defer c.mu.Unlock() | ||||
| 	c.cancelFuncs[id] = fn | ||||
| } | ||||
|  | ||||
| // Delete deletes a cancel func from the set given an id. | ||||
| func (c *Cancelations) Delete(id string) { | ||||
| 	c.mu.Lock() | ||||
| 	defer c.mu.Unlock() | ||||
| 	delete(c.cancelFuncs, id) | ||||
| } | ||||
|  | ||||
| // Get returns a cancel func given an id. | ||||
| func (c *Cancelations) Get(id string) context.CancelFunc { | ||||
| 	c.mu.Lock() | ||||
| 	defer c.mu.Unlock() | ||||
| 	return c.cancelFuncs[id] | ||||
| } | ||||
|  | ||||
| // GetAll returns all cancel funcs. | ||||
| func (c *Cancelations) GetAll() []context.CancelFunc { | ||||
| 	c.mu.Lock() | ||||
| 	defer c.mu.Unlock() | ||||
| 	var res []context.CancelFunc | ||||
| 	for _, fn := range c.cancelFuncs { | ||||
| 		res = append(res, fn) | ||||
| 	} | ||||
| 	return res | ||||
| } | ||||
|   | ||||
| @@ -410,3 +410,19 @@ func (r *RDB) ClearProcessInfo(ps *base.ProcessInfo) error { | ||||
| 	key := base.ProcessInfoKey(ps.Host, ps.PID) | ||||
| 	return clearProcessInfoCmd.Run(r.client, []string{base.AllProcesses, key}).Err() | ||||
| } | ||||
|  | ||||
| // CancelationPubSub returns a pubsub for cancelation messages. | ||||
| func (r *RDB) CancelationPubSub() (*redis.PubSub, error) { | ||||
| 	pubsub := r.client.Subscribe(base.CancelChannel) | ||||
| 	_, err := pubsub.Receive() | ||||
| 	if err != nil { | ||||
| 		return nil, err | ||||
| 	} | ||||
| 	return pubsub, nil | ||||
| } | ||||
|  | ||||
| // PublishCancelation publish cancelation message to all subscribers. | ||||
| // The message is a string representing the task to be canceled. | ||||
| func (r *RDB) PublishCancelation(id string) error { | ||||
| 	return r.client.Publish(base.CancelChannel, id).Err() | ||||
| } | ||||
|   | ||||
		Reference in New Issue
	
	Block a user