huangdijia / laravel-trigger
基于 MySQLReplication 的 MySQL 触发器。
资助包维护!
huangdijia
hdj.me/sponsors
v6.0.0-beta.3
2024-06-06 12:38 UTC
Requires
- php: ^8.2
- illuminate/console: ^11.0
- illuminate/support: ^11.0
- krowinski/php-mysql-replication: ^8.0
Requires (Dev)
- huangdijia/php-coding-standard: ^2.1
- orchestra/testbench: ^9.0
- phpstan/phpstan: ^1.11
- dev-main / 6.x-dev
- v6.0.0-beta.3
- v6.0.0-beta.2
- v6.0.0-beta.1
- 5.x-dev
- v5.0.0-beta.1
- 4.x-dev
- v4.1.0
- v4.0.3
- v4.0.2
- v4.0.1
- 4.0.0
- 3.x-dev
- v3.0.1
- 3.0.0
- 2.x-dev
- v2.2.1
- 2.2.0
- 2.1.4
- 2.1.3
- 2.1.2
- 2.1.1
- 2.1.0
- 2.0.3
- 2.0.2
- 2.0.1
- 2.0.0
- 1.2.1
- 1.2.0
- 1.1.15
- 1.1.14
- 1.1.13
- 1.1.12
- 1.1.11
- 1.1.10
- 1.1.9
- 1.1.8
- 1.1.7
- 1.1.6
- 1.1.5
- 1.1.4
- 1.1.3
- 1.1.2
- 1.1.1
- 1.1.0
This package is auto-updated.
Last update: 2024-09-07 00:57:55 UTC
README
订阅 MySQL 事件,类似于 jQuery,基于 php-mysql-replication
MySQL 服务器设置
在您的 MySQL 服务器配置文件中,您需要启用复制
[mysqld]
server-id = 1
log_bin = /var/log/mysql/mysql-bin.log
expire_logs_days = 10
max_binlog_size = 100M
binlog_row_image = full
binlog-format = row #Very important if you want to receive write, update and delete row events
Mysql replication events explained https://dev.mysqlserver.cn/doc/internals/en/event-meanings.html
Mysql 用户权限
GRANT REPLICATION SLAVE, REPLICATION CLIENT ON *.* TO 'user'@'host'; GRANT SELECT ON `dbName`.* TO 'user'@'host';
安装
Laravel
安装
composer require "huangdijia/laravel-trigger:^4.0"
发布配置
php artisan vendor:publish --provider="Huangdijia\Trigger\TriggerServiceProvider"
Lumen
安装
composer require "huangdijia/laravel-trigger:^4.0"
编辑 bootstrap/app.php
添加
$app->register(Huangdijia\Trigger\TriggerServiceProvider::class); ... $app->configure('trigger');
发布配置和路由
php artisan trigger:install [--force]
配置
编辑 .env
,添加
TRIGGER_HOST=192.168.xxx.xxx TRIGGER_PORT=3306 TRIGGER_USER=username TRIGGER_PASSWORD=password ...
用法
php artisan trigger:start [-R=xxx]
订阅者
<?php namespace App\Listeners; use Huangdijia\Trigger\EventSubscriber; class ExampeSubscriber extends EventSubscriber { public function onUpdate(UpdateRowsDTO $event) { // } public function onDelete(DeleteRowsDTO $event) { // } public function onWrite(WriteRowsDTO $event) { // } }
更多订阅者用法
事件路由
通用
$trigger->on('database.table', 'write', function($event) { /* do something */ });
多表和多事件
$trigger->on('database.table1,database.table2', 'write,update', function($event) { /* do something */ });
多事件
$trigger->on('database.table1,database.table2', [ 'write' => function($event) { /* do something */ }, 'update' => function($event) { /* do something */ }, ]);
作为控制器执行动作
$trigger->on('database.table', 'write', 'App\\Http\\Controllers\\ExampleController'); // call default method 'handle' $trigger->on('database.table', 'write', 'App\\Http\\Controllers\\ExampleController@write');
作为可调用执行动作
class Foo { public static function bar($event) { dump($event); } } $trigger->on('database.table', 'write', 'Foo@bar'); // call default method 'handle' $trigger->on('database.table', 'write', ['Foo', 'bar']);
作为作业执行动作
作业
namespace App\Jobs; class ExampleJob extends Job { private $event; public function __construct($event) { $this->event = $event; } public function handle() { dump($this->event); } }
路由
$trigger->on('database.table', 'write', 'App\Jobs\ExampleJob'); // call default method 'dispatch' $trigger->on('database.table', 'write', 'App\Jobs\ExampleJob@dispatch_now');
事件列表
php artisan trigger:list [-R=xxx]
终止
php artisan trigger:terminate [-R=xxx]