jeylabs / laravel-sns-sqs-sub-pub
一个简单的Laravel服务提供者,用于添加一个新的队列连接器以处理SNS订阅队列。
1.0.3
2019-05-01 07:42 UTC
Requires
- php: >=7.0
- ext-json: *
- aws/aws-sdk-php: ^3.91
- illuminate/queue: ^5.4
- illuminate/support: ^5.4
This package is auto-updated.
Last update: 2024-08-29 05:00:33 UTC
README
是Laravel中Illuminate/Queue队列系统的一个简单扩展,该系统在Laravel和Lumen中使用。
使用此连接器允许通过SQS从SNS订阅中发送的消息与Illuminate\Queue\Jobs\SqsJob一起处理。
这在微服务架构中特别有用,其中多个服务订阅一个常见主题,使用自己的队列并向SNS发布事件。
需求
- Laravel (测试版本5.8)
- 或 Lumen (测试版本5.8)
安装
您可以通过composer安装此包
composer require jeylabs/laravel-sns-sqs-sub-pub
您可以选择使用以下命令发布配置文件:
php artisan vendor:publish --provider="Jeylabs\SnsSqsPubSub\SnsSqsPubSubServiceProvider" --tag="config"
这是发布配置文件的内容
<?php return [ 'default_topic' => 'SampleTopic', 'default_auth_driver' => null, 'map' => [ \App\Jobs\TestSQSJob::class => 'SampleTopic', ], 'published_attributes' => [ 'id', 'created_at', 'updated_at' ], 'sns' => [ 'key' => env('SNS_SQS_PUB_SUB_AWS_ACCESS_KEY'), 'secret' => env('SNS_SQS_PUB_SUB_AWS_SECRET_ACCESS_KEY'), 'region' => env('SNS_SQS_PUB_SUB_AWS_DEFAULT_REGION', 'us-east-1'), ] ];
配置
您需要在config/queue.php中配置队列连接。
<?php return [ 'connections' => [ 'sns-sqs-sub-pub' => [ 'driver' => 'sns-sqs-sub-pub', 'key' => env('SNS_SQS_PUB_SUB_AWS_ACCESS_KEY'), 'secret' => env('SNS_SQS_PUB_SUB_AWS_SECRET_ACCESS_KEY'), 'prefix' => env('SNS_SQS_PUB_SUB_SQS_PREFIX', 'https://sqs.ap-southeast-1.amazonaws.com/your-account-id'), 'queue' => env('SNS_SQS_PUB_SUB_QUEUE_URL', 'your-queue-name'), 'region' => env('SNS_SQS_PUB_SUB_AWS_DEFAULT_REGION', 'us-east-1'), ], ], ];
一旦配置了sns-sqs-sub-pub队列连接器,您可以通过在.env文件中将队列驱动设置为'sns-sqs-sub-pub'来开始使用它。
作业类示例
<?php use Illuminate\Bus\Queueable; use Illuminate\Queue\SerializesModels; use Illuminate\Queue\InteractsWithQueue; use Illuminate\Contracts\Queue\ShouldQueue; use Illuminate\Foundation\Bus\Dispatchable; use Illuminate\Support\Facades\Log; class TestSQSJob implements ShouldQueue { use Dispatchable, InteractsWithQueue, Queueable, SerializesModels; protected $passedInData; /** * Create a new job instance. * * @param array $data */ public function __construct(array $data) { // $data is array containing the msg content from SQS $this->passedInData = $data; } /** * Execute the job. * * @return void */ public function handle() { Log::info(json_encode($this->passedInData)); // Check laravel.log, it should now contain msg string. } }
已发布的事件
<?php namespace App; use Illuminate\Database\Eloquent\Model; use Jeylabs\SnsSqsPubSub\Traits\SNSPublisher; class Post extends Model { use SNSPublisher; /** * @var array * Optional (default value is [] ) * Witch are the attributes should only from SNS message */ static $publishedAttributes = [ 'id', 'created_at', 'updated_at' ]; /** * @var array * Optional (default value is [created','updated','deleted','restored'] ) * Witch events should send to SNS */ static $publishEvents = ['created', 'updated']; /** * @var string * Optional (default value is load from config ) * Publish SNS topic */ static $publishTopic = 'SampleTopic'; /** * Or * static $publishTopic = [ * 'created' => 'SampleTopic' * ]; */ }
您需要配置.env文件
SNS_SQS_PUB_SUB_AWS_SNS_DEFAULT_TOPIC=sampletopic SNS_SQS_PUB_SUB_AWS_ACCESS_KEY= SNS_SQS_PUB_SUB_AWS_SECRET_ACCESS_KEY= SNS_SQS_PUB_SUB_AWS_DEFAULT_REGION=ap-southeast-1 SNS_SQS_PUB_SUB_SQS_PREFIX=https://sqs.ap-southeast-1.amazonaws.com/your-account-id SNS_SQS_PUB_SUB_QUEUE_URL=https://sqs.ap-southeast-1.amazonaws.com/your-account-id/your-queue-name