mirror of
				https://github.com/hibiken/asynq.git
				synced 2025-10-26 11:16:12 +08:00 
			
		
		
		
	
			
				
					
						
					
					39c4904dae1c8f71a9aa4ab5464df9213d6215e0
				
			
			
		
	Add methods to RDB to enqueue a task sitting in ZSET (scheduled, retry, dead).
Asynq 
Asynq is a simple asynchronous task queue library in Go.
Requirements
- Redis: 2.6+
- Go: 1.12+
Installation
go get -u github.com/hibiken/asynq
Getting Started
- Import asynqin your file.
import "github.com/hibiken/asynq"
- Create a Clientinstance to create tasks.
func main() {
    client := asynq.NewClient(&asynq.RedisOpt{
        Addr: "localhost:6379",
    })
    t1 := &asynq.Task{
        Type: "send_welcome_email",
        Payload: map[string]interface{}{
          "recipient_id": 1234,
        },
    }
    t2 := &asynq.Task{
        Type: "send_reminder_email",
        Payload: map[string]interface{}{
          "recipient_id": 1234,
        },
    }
    // process the task immediately.
    client.Process(t1, time.Now())
    // process the task 24 hours later.
    client.Process(t2, time.Now().Add(24 * time.Hour))
}
- Create a Backgroundinstance to process tasks.
func main() {
    bg := asynq.NewBackground(10, &asynq.RedisOpt{
        Addr: "localhost:6379",
    })
    bg.Run(asynq.HandlerFunc(handler))
}
// if handler returns an error or panics, the task will be retried after some delay.
func handler(t *asynq.Task) error {
    switch t.Type {
        case "send_welcome_email":
            rid, ok := t.Payload["recipient_id"]
            if !ok {
                return fmt.Errorf("recipient_id not found in payload")
            }
            fmt.Printf("Send Welcome Email to %d\n", rid.(int))
        // ... handle other task types.
        default:
            return fmt.Errorf("unexpected task type: %s", t.Type)
    }
    return nil
}
Description
				
					Languages
				
				
								
								
									Go
								
								100%