2
0
mirror of https://github.com/hibiken/asynq.git synced 2025-01-11 23:43:38 +08:00
golang基于redis的异步队列
Go to file
2020-03-13 21:04:45 -07:00
.github/ISSUE_TEMPLATE Update issue templates 2019-12-27 10:45:45 -08:00
.travis Run and compare benchmarks after successful ci-build 2020-01-30 21:38:16 -08:00
docs/assets [ci skip] Update readme 2020-03-02 07:06:11 -08:00
internal Add comments to exported types and functions from internal/log package 2020-03-13 21:04:45 -07:00
tools fix typo 2020-03-13 20:02:26 -07:00
.gitignore [ci skip] Allow config file to set default values for flags 2020-01-19 09:10:48 -08:00
.travis.yml Run travis build with go v1.14.x 2020-02-27 08:28:35 -08:00
asynq_test.go Extract out log package 2020-03-09 07:17:52 -07:00
asynq.go Add ServeMux type 2020-03-01 15:53:18 -08:00
background_test.go Change Client APIs 2020-02-23 20:40:40 -08:00
background.go Allow custom logger to be used in Background 2020-03-12 08:40:37 -07:00
benchmark_test.go Change Client APIs 2020-02-23 20:40:40 -08:00
CHANGELOG.md Update changelog 2020-03-13 17:27:20 -07:00
client_test.go Simplify code with gofmt -s 2020-03-13 14:24:24 -07:00
client.go Add Deadline option when enqueuing tasks 2020-03-08 17:12:42 -07:00
CONTRIBUTING.md [ci skip] Add contribution doc 2020-02-08 09:48:04 -08:00
doc.go Change Client APIs 2020-02-23 20:40:40 -08:00
go.mod Update redis package to v7.2.0 2020-02-22 21:21:55 -08:00
go.sum Update redis package to v7.2.0 2020-02-22 21:21:55 -08:00
heartbeat_test.go Extract out log package 2020-03-09 07:17:52 -07:00
heartbeat.go Allow custom logger to be used in Background 2020-03-12 08:40:37 -07:00
LICENSE Add MIT License 2019-11-30 10:21:25 -08:00
payload_test.go Simplify code with gofmt -s 2020-03-13 14:24:24 -07:00
payload.go [ci skip] Update docs 2020-01-16 21:04:46 -08:00
processor_test.go Extract out log package 2020-03-09 07:17:52 -07:00
processor.go Allow custom logger to be used in Background 2020-03-12 08:40:37 -07:00
README.md Minor tweak to readme example code 2020-03-13 17:27:20 -07:00
scheduler_test.go Extract out log package 2020-03-09 07:17:52 -07:00
scheduler.go Allow custom logger to be used in Background 2020-03-12 08:40:37 -07:00
servemux_test.go Add Use method to better support middlewares with ServeMux 2020-03-13 14:13:17 -07:00
servemux.go Add Use method to better support middlewares with ServeMux 2020-03-13 14:13:17 -07:00
subscriber_test.go Extract out log package 2020-03-09 07:17:52 -07:00
subscriber.go Allow custom logger to be used in Background 2020-03-12 08:40:37 -07:00
syncer_test.go Extract out log package 2020-03-09 07:17:52 -07:00
syncer.go Allow custom logger to be used in Background 2020-03-12 08:40:37 -07:00

Asynq

Build Status License: MIT Go Report Card GoDoc Gitter chat codecov

Asynq is a simple Go library for queueing tasks and processing them in the background with workers.
It is backed by Redis and it is designed to have a low barrier to entry. It should be integrated in your web stack easily.

Important Note: Current major version is zero (v0.x.x) to accomodate rapid development and fast iteration while getting early feedback from users. The public API could change without a major version update before v1.0.0 release.

Task Queue Diagram

Quickstart

First, make sure you are running a Redis server locally.

$ redis-server

To create and schedule tasks, use Client and provide a task and when to enqueue the task.
A task will be processed by a background worker as soon as the task gets enqueued.
Scheduled tasks will be stored in Redis and will be enqueued at the specified time.

func main() {
    r := &asynq.RedisClientOpt{
        Addr: "127.0.0.1:6379",
    }

    c := asynq.NewClient(r)

    // Example 1: Enqueue task to be processed immediately.

    t := asynq.NewTask("email:signup", map[string]interface{}{"user_id": 42})
    err := c.Enqueue(t)
    if err != nil {
        log.Fatal("could not enqueue task: %v", err)
    } 


    // Example 2: Schedule task to be processed in the future.

    t = asynq.NewTask("email:reminder", map[string]interface{}{"user_id": 42})
    err = c.EnqueueIn(24*time.Hour, t)
    if err != nil {
        log.Fatal("could not schedule task: %v", err)
    }


    // Example 3: Pass options to tune task processing behavior. 
    // Options include MaxRetry, Queue, Timeout, Deadline, etc.

    t = asynq.NewTask("email:reminder", map[string]interface{}{"user_id": 42})
    err = c.Enqueue(t, asynq.MaxRetry(10), asynq.Queue("critical"), asynq.Timeout(time.Minute))
    if err != nil {
        log.Fatal("could not enqueue task: %v", err)
    }
}

To start the background workers, use Background and provide your Handler to process the tasks.

Handler is an interface with one method ProcessTask with the following signature.

// ProcessTask should return nil if the processing of a task is successful.
//
// If ProcessTask return a non-nil error or panics, the task will be retried after delay.
type Handler interface {
    ProcessTask(context.Context, *asynq.Task) error
}

You can optionally use ServeMux to create a handler, just as you would with "net/http" Handler.

func main() {
    r := &asynq.RedisClientOpt{
        Addr: "127.0.0.1:6379",
    }

    bg := asynq.NewBackground(r, &asynq.Config{
        // Specify how many concurrent workers to use
        Concurrency: 10,
        // Optionally specify multiple queues with different priority.
        Queues: map[string]int{
            "critical": 6,
            "default":  3,
            "low":      1,
        },
        // See the godoc for other configuration options
    })

    // mux maps a type to a handler
    mux := asynq.NewServeMux()
    mux.HandleFunc("email:signup", signupEmailHandler)
    mux.HandleFunc("email:reminder", reminderEmailHandler)
    // ...register other handlers...

    bg.Run(mux)
}

// function with the same signature as the sole method for the Handler interface.
func signupEmailHandler(ctx context.Context, t *asynq.Task) error {
    id, err := t.Payload.GetInt("user_id")
    if err != nil {
        return err
    }
    fmt.Printf("Send welcome email to user %d\n", id)
    // ...your email sending logic...
    return nil
}

For a more detailed walk-through of the library, see our Getting Started Guide.

To Learn more about asynq features and APIs, see our Wiki and godoc.

Command Line Tool

Asynq ships with a command line tool to inspect the state of queues and tasks.

Here's an example of running the stats command.

Gif

For details on how to use the tool, refer to the tool's README.

Installation

To install asynq library, run the following command:

go get -u github.com/hibiken/asynq

To install the CLI tool, run the following command:

go get -u github.com/hibiken/asynq/tools/asynqmon

Requirements

Dependency Version
Redis v2.8+
Go v1.12+

Contributing

We are open to, and grateful for, any contributions (Github issues/pull-requests, feedback on Gitter channel, etc) made by the community. Please see the Contribution Guide before contributing.

Acknowledgements

  • Sidekiq : Many of the design ideas are taken from sidekiq and its Web UI
  • RQ : Client APIs are inspired by rq library.
  • Cobra : Asynqmon CLI is built with cobra

License

Asynq is released under the MIT license. See LICENSE.