mirror of
				https://github.com/hibiken/asynq.git
				synced 2025-10-25 23:06:12 +08:00 
			
		
		
		
	Update CHANGELOG
This commit is contained in:
		
							
								
								
									
										28
									
								
								CHANGELOG.md
									
									
									
									
									
								
							
							
						
						
									
										28
									
								
								CHANGELOG.md
									
									
									
									
									
								
							| @@ -7,6 +7,15 @@ and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0 | ||||
|  | ||||
| ## [Unreleased] | ||||
|  | ||||
| **IMPORTATNT**: Please run `asynq migrate` command to migrate from the previous versions. | ||||
|  | ||||
| ### Changed | ||||
|  | ||||
| - Renamed `DeadTask` to `ArchivedTask`. | ||||
| - Renamed the operation `Kill` to `Archive` in `Inpsector`. | ||||
| - Print stack track when Handler panics. | ||||
| - Include a file name and a line number in error message when recovering from a panic. | ||||
|  | ||||
| ### Added | ||||
|  | ||||
| - `SkipRetry` error is added to be used as a return value from `Handler`. | ||||
| @@ -22,7 +31,6 @@ and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0 | ||||
|  | ||||
| - Fixed processor to wait for specified time duration before forcefully shutdown workers. | ||||
|  | ||||
|  | ||||
| ## [0.13.0] - 2020-10-13 | ||||
|  | ||||
| ### Added | ||||
| @@ -45,9 +53,11 @@ and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0 | ||||
| **IMPORTANT**: If you are upgrading from a previous version, please install the latest version of the CLI `go get -u github.com/hibiken/asynq/tools/asynq` and run `asynq migrate` command. No process should be writing to Redis while you run the migration command. | ||||
|  | ||||
| ## The semantics of queue have changed | ||||
| Previously, we called tasks that are ready to be processed *"Enqueued tasks"*, and other tasks that are scheduled to be processed in the future *"Scheduled tasks"*, etc. | ||||
| We changed the semantics of *"Enqueue"* slightly; All tasks that client pushes to Redis are *Enqueued* to a queue. Within a queue, tasks will transition from one state to another.  | ||||
|  | ||||
| Previously, we called tasks that are ready to be processed _"Enqueued tasks"_, and other tasks that are scheduled to be processed in the future _"Scheduled tasks"_, etc. | ||||
| We changed the semantics of _"Enqueue"_ slightly; All tasks that client pushes to Redis are _Enqueued_ to a queue. Within a queue, tasks will transition from one state to another. | ||||
| Possible task states are: | ||||
|  | ||||
| - `Pending`: task is ready to be processed (previously called "Enqueued") | ||||
| - `Active`: tasks is currently being processed (previously called "InProgress") | ||||
| - `Scheduled`: task is scheduled to be processed in the future | ||||
| @@ -59,23 +69,28 @@ Possible task states are: | ||||
| --- | ||||
|  | ||||
| ### Changed | ||||
|  | ||||
| #### `Client` | ||||
|  | ||||
| Use `ProcessIn` or `ProcessAt` option to schedule a task instead of `EnqueueIn` or `EnqueueAt`. | ||||
|  | ||||
| | Previously                  | v0.12.0                                    | | ||||
| |-----------------------------|--------------------------------------------| | ||||
| | --------------------------- | ------------------------------------------ | | ||||
| | `client.EnqueueAt(t, task)` | `client.Enqueue(task, asynq.ProcessAt(t))` | | ||||
| | `client.EnqueueIn(d, task)` | `client.Enqueue(task, asynq.ProcessIn(d))` | | ||||
|  | ||||
| #### `Inspector` | ||||
|  | ||||
| All Inspector methods are scoped to a queue, and the methods take `qname (string)` as the first argument.   | ||||
| `EnqueuedTask` is renamed to `PendingTask` and its corresponding methods.   | ||||
| `InProgressTask` is renamed to `ActiveTask` and its corresponding methods.   | ||||
| Command "Enqueue" is replaced by the verb "Run" (e.g. `EnqueueAllScheduledTasks` --> `RunAllScheduledTasks`) | ||||
|  | ||||
| #### `CLI` | ||||
|  | ||||
| CLI commands are restructured to use subcommands. Commands are organized into a few management commands: | ||||
| To view details on any command, use `asynq help <command> <subcommand>`. | ||||
|  | ||||
| - `asynq stats` | ||||
| - `asynq queue [ls inspect history rm pause unpause]` | ||||
| - `asynq task [ls cancel delete kill run delete-all kill-all run-all]` | ||||
| @@ -84,19 +99,23 @@ To view details on any command, use `asynq help <command> <subcommand>`. | ||||
| ### Added | ||||
|  | ||||
| #### `RedisConnOpt` | ||||
|  | ||||
| - `RedisClusterClientOpt` is added to connect to Redis Cluster. | ||||
| - `Username` field is added to all `RedisConnOpt` types in order to authenticate connection when Redis ACLs are used. | ||||
|  | ||||
| #### `Client` | ||||
|  | ||||
| - `ProcessIn(d time.Duration) Option` and `ProcessAt(t time.Time) Option` are added to replace `EnqueueIn` and `EnqueueAt` functionality. | ||||
|  | ||||
| #### `Inspector` | ||||
|  | ||||
| - `Queues() ([]string, error)` method is added to get all queue names. | ||||
| - `ClusterKeySlot(qname string) (int64, error)` method is added to get queue's hash slot in Redis cluster. | ||||
| - `ClusterNodes(qname string) ([]ClusterNode, error)` method is added to get a list of Redis cluster nodes for the given queue. | ||||
| - `Close() error` method is added to close connection with redis. | ||||
|  | ||||
| ### `Handler` | ||||
|  | ||||
| - `GetQueueName(ctx context.Context) (string, bool)` helper is added to extract queue name from a context. | ||||
|  | ||||
| ## [0.11.0] - 2020-07-28 | ||||
| @@ -131,7 +150,6 @@ To view details on any command, use `asynq help <command> <subcommand>`. | ||||
|  | ||||
| - Fixes the JSON number overflow issue (https://github.com/hibiken/asynq/issues/166). | ||||
|  | ||||
|  | ||||
| ## [0.9.2] - 2020-06-08 | ||||
|  | ||||
| ### Added | ||||
|   | ||||
| @@ -202,9 +202,9 @@ type RetryTask struct { | ||||
| } | ||||
|  | ||||
| // ArchivedTask is a task archived for debugging and inspection purposes, and | ||||
| // ArchivedTask won't be retried automatically. | ||||
| // it won't be retried automatically. | ||||
| // A task can be archived when the task exhausts its retry counts or manually | ||||
| // archived by a user via CLI or Inspector. | ||||
| // archived by a user via the CLI or Inspector. | ||||
| type ArchivedTask struct { | ||||
| 	*Task | ||||
| 	ID           string | ||||
|   | ||||
		Reference in New Issue
	
	Block a user