mirror of
https://github.com/hibiken/asynq.git
synced 2024-12-26 07:42:17 +08:00
f3a23b9b12
This change makes it impossible to mutate payload within Handler or RetryDelayFunc.
51 lines
1.4 KiB
Go
51 lines
1.4 KiB
Go
// Copyright 2020 Kentaro Hibino. All rights reserved.
|
|
// Use of this source code is governed by a MIT license
|
|
// that can be found in the LICENSE file.
|
|
|
|
/*
|
|
Package asynq provides a framework for background task processing.
|
|
|
|
The Client is used to register a task to be processed at the specified time.
|
|
|
|
client := asynq.NewClient(redis)
|
|
|
|
t := asynq.NewTask(
|
|
"send_email",
|
|
map[string]interface{}{"user_id": 42})
|
|
|
|
err := client.Schedule(t, time.Now().Add(time.Minute))
|
|
|
|
The Background is used to run the background task processing with a given
|
|
handler.
|
|
bg := asynq.NewBackground(redis, &asynq.Config{
|
|
Concurrency: 10,
|
|
})
|
|
|
|
bg.Run(handler)
|
|
|
|
Handler is an interface with one method ProcessTask which
|
|
takes a task and returns an error. Handler should return nil if
|
|
the processing is successful, otherwise return a non-nil error.
|
|
If handler returns a non-nil error, the task will be retried in the future.
|
|
|
|
Example of a type that implements the Handler interface.
|
|
type TaskHandler struct {
|
|
// ...
|
|
}
|
|
|
|
func (h *TaskHandler) ProcessTask(task *asynq.Task) error {
|
|
switch task.Type {
|
|
case "send_email":
|
|
id, err := task.Payload.GetInt("user_id")
|
|
// send email
|
|
case "generate_thumbnail":
|
|
// generate thumbnail image
|
|
//...
|
|
default:
|
|
return fmt.Errorf("unepected task type %q", task.Type)
|
|
}
|
|
return nil
|
|
}
|
|
*/
|
|
package asynq
|