Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/freyo/laravel-queue-cmq
📦 Tencent Cloud Message Queue driver for Laravel Queue
https://github.com/freyo/laravel-queue-cmq
cmq cmq-queue cmq-topic laravel laravel-queues php queue-drivers
Last synced: about 12 hours ago
JSON representation
📦 Tencent Cloud Message Queue driver for Laravel Queue
- Host: GitHub
- URL: https://github.com/freyo/laravel-queue-cmq
- Owner: freyo
- License: mit
- Created: 2017-11-15T02:07:12.000Z (almost 7 years ago)
- Default Branch: master
- Last Pushed: 2021-08-19T05:07:57.000Z (about 3 years ago)
- Last Synced: 2024-09-18T01:19:10.139Z (16 days ago)
- Topics: cmq, cmq-queue, cmq-topic, laravel, laravel-queues, php, queue-drivers
- Language: PHP
- Homepage: https://intl.cloud.tencent.com/product/cmq
- Size: 120 KB
- Stars: 26
- Watchers: 2
- Forks: 9
- Open Issues: 1
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
## Installation
```shell
composer require freyo/laravel-queue-cmq
```## Configure
**Laravel 5.5+ uses Package Auto-Discovery, so doesn't require you to manually add the ServiceProvider.**
1. `config/app.php`:
```php
'providers' => [
// ...
Freyo\LaravelQueueCMQ\LaravelQueueCMQServiceProvider::class,
]
```
2. `.env`:```
QUEUE_DRIVER=cmq
CMQ_SECRET_KEY=
CMQ_SECRET_ID=
CMQ_QUEUE_HOST=https://cmq-queue-{region}.api.qcloud.com
CMQ_QUEUE=queue_name #default queue name
CMQ_QUEUE_POLLING_WAIT_SECONDS=0
CMQ_TOPIC_ENABLE=false # set to true to use topic
CMQ_TOPIC_FILTER=routing # or msgtag
CMQ_TOPIC_HOST=https://cmq-topic-{region}.api.qcloud.com
CMQ_TOPIC=topic_name
```
#### Tips
- Region should be replaced with a specific region: gz (Guangzhou), sh (Shanghai), or bj (Beijing).
- Domain for public network API request: cmq-queue-region.api.qcloud.com / cmq-topic-region.api.qcloud.com
- Domain for private network API request: cmq-queue-region.api.tencentyun.com / cmq-topic-region.api.tencentyun.com
## UsageOnce you completed the configuration you can use Laravel Queue API. If you used other queue drivers you do not need to change anything else. If you do not know how to use Queue API, please refer to the official Laravel documentation: http://laravel.com/docs/queues
### Example
#### Dispatch Jobs
The default connection name is `cmq`
```php
//use queue only
Job::dispatch()->onConnection('connection-name')->onQueue('queue-name');
// or dispatch((new Job())->onConnection('connection-name')->onQueue('queue-name'))
//use topic and tag filter
Job::dispatch()->onConnection('connection-name')->onQueue('tag1,tag2,tag3');
// or dispatch((new Job())->onConnection('connection-name')->onQueue('tag1,tag2,tag3'))
//use topic and routing filter
Job::dispatch()->onConnection('connection-name')->onQueue('routing-key');
// or dispatch((new Job())->onConnection('connection-name')->onQueue('routing-key'))
```#### Multiple Queues
Configure `config/queue.php`
```php
'connections' => [
//...
'new-connection-name' => [
'driver' => 'cmq',
'secret_key' => 'your-secret-key',
'secret_id' => 'your-secret-id',
'queue' => 'your-queue-name',
'options' => [
'queue' => [
'host' => 'https://cmq-queue-region.api.qcloud.com',
'name' => 'your-queue-name',
'polling_wait_seconds' => 0, // 0-30 seconds
'retries' => 3,
],
'topic' => [
'enable' => false,
'filter' => 'routing', // routing or msgtag
'host' => 'https://cmq-topic-region.api.qcloud.com',
'name' => 'your-topic-name',
'retries' => 3,
],
],
'plain' => [
'enable' => false,
'job' => 'App\Jobs\CMQPlainJob@handle',
],
];
//...
];
```#### Process Jobs
```bash
php artisan queue:work {connection-name} --queue={queue-name}
```#### Plain Mode
Configure `.env`
```
CMQ_PLAIN_ENABLE=true
CMQ_PLAIN_JOB=App\Jobs\CMQPlainJobHandler@handle
```Create a job implements `PlainPayload` interface. The method `getPayload` must return a sting value.
```php
payload = $payload;
}
/**
* Get the plain payload of the job.
*
* @return string
*/
public function getPayload()
{
return $this->payload;
}
}
```Create a plain job handler
```php
release();
// delete message when processed.
if (! $job->isDeletedOrReleased()) {
$job->delete();
}
}
}
```## References
- [Product Documentation](https://intl.cloud.tencent.com/document/product/406)
## License
The MIT License (MIT). Please see [License File](LICENSE) for more information.
[![FOSSA Status](https://app.fossa.io/api/projects/git%2Bgithub.com%2Ffreyo%2Flaravel-queue-cmq.svg?type=large)](https://app.fossa.io/projects/git%2Bgithub.com%2Ffreyo%2Flaravel-queue-cmq?ref=badge_large)