All notable changes to this project will be documented in this file.
The format is based on "Keep a Changelog", and this project adheres to Semantic Versioning.
Handler
interface has changed.ProcessTask
method takes two argumentscontext.Context
and*asynq.Task
Queues
field inConfig
has change frommap[string]uint
tomap[string]int
Client
can optionally schedule task withasynq.Timeout(duration)
to specify timeout duration for task. Default is no timeout.asynqmon cancel [task id]
will send a cancelation signal to the goroutine processing the speicified task.
asynqmon ps
was added to list all background worker processes
- Fixed restoring unfinished tasks back to correct queues.
asynqmon ls
command is now paginated (default 30 tasks from first page)asynqmon ls enqueued:[queue name]
requires queue name to be specified
- More structured log messages
- Prevent spamming logs with a bunch of errors when Redis connection is lost
- Fixed and updated README doc
- NewTask constructor
Queues
option inConfig
to specify mutiple queues with priority levelClient
can schedule a task withasynq.Queue(name)
to specify which queue to useStrictPriority
option inConfig
to specify whether the priority should be followed strictlyRedisConnOpt
to abstract away redis client implementation- [CLI]
asynqmon rmq
command to remove queue
Client
andBackground
constructors takeRedisConnOpt
as their first argument.asynqmon stats
now shows the total of all enqueued tasks under "Enqueued"asynqmon stats
now shows each queue's task countasynqmon history
now doesn't take any arguments and shows data from the last 10 days by default (use--days
flag to change the number of days)- Task type is now immutable (i.e., Payload is read-only)
- Initial version of asynq package
- Initial version of asynqmon CLI