zwei / event-worker
Zwei 事件工作包。
Requires
- zwei/base: ~1
Requires (Dev)
- phpunit/phpunit: ^5.6
This package is auto-updated.
Last update: 2024-09-06 12:31:01 UTC
README
业务频繁变动,频繁增减活动,导致开发修改现有业务逻辑,造成程序混乱,质量无法保证。同时也导致测试进行了大量重复而无需的测试,从而浪费大量人力成本,而不能得到预期结果。
注意
Event Worker 当前版本只针对中小型企业,因为部署简单,你可以快速安装和使用。之后会有 Event Worker RabbitMQ,针对大型企业和高并发业务场景。
使用场景
- 主要业务不变,一些像活动、注册、登录、购买送积分、发短信等
- saas平台使用为每个客户部署环境,很多公司用docker快速部署环境,环境创建后会导入sql,但是可能创建成功事件不确定,我们可以发送一个import_event事件来解决这个问题
案例
1. 用户注册
这个月是送积分,可能下个月送红包
2. 比如活动,每次节假日的活动规则不一样
- 3.8妇女节,女性用户登录(可以获得专属优惠券,购买商品后可以获得额外返现或者双倍积分等规则)
- 5.1劳动节邀请好友(获得实物大礼包,好友购买商品,送2元红包,1.5倍积分,邀请人获得3元红包,10个积分),购买商品送劳动币。
- 国庆节活动登录、注册、购买商品送爱国币。
问题:
- 登录送积分、送红包
- “5.1”劳动节购买商品送劳动币等
- 国庆登录、注册、购买送爱国币
在这个场景中,实际上登录、购买、邀请好友等逻辑没有变化,每次活动或需求程序员都要根据需求不断修改业务逻辑,每次修改业务,测试都要做一些重复的测试,那么有没有办法简化呢。
解决方案:
我们使用事件(Event),在注册、登录、购买、邀请好友等操作中都发送相应的事件(注册register_event、登录login_event、购买product_buy_event、邀请好友inviting_friend_event),我们可以监听不同的消费者监听同一事件,例如我们登录要送积分,国庆登录又要送爱国币,那么登录(login_event)事件同时要送积分和爱国币,我们可以分别写两个消费者去监听登录事件,一个登录送积分消费者,一个国庆消费者送爱国币,当国庆结束后我们可以停止国庆消费者,而不必停止登录送积分消费者。
事件发送示例
<?php $sendData = [ 'productId' => 1,// 购买产品id 'quantity' => 10,// 购买数量 'couponId' => 0,// 优惠券id 'uid' => 10,//购买用户 ]; // 用户购买产品 \Zwei\EventWork\EventSend::send('BUY_PRODUCT', $data);
Event Worker 使用示例
使用示例Event Worker App
数据库配置文件"config/bao-loan.yml"
事件、模块、计划任务配置文件"config/event-worker.conf.yml"
单元测试使用
--bootstrap 在测试前先运行一个 "bootstrap" PHP 文件
- --bootstrap 引导测试: phpunit --bootstrap vendor/autoload.php tests/
- --bootstrap 引导测试: phpunit --bootstrap tests/TestInit.php tests/
D:\phpStudy\php\php-7.0.12-nts\php.exe vendor\phpunit\phpunit\phpunit --bootstrap tests/TestInit.php tests/EventTest.php D:\phpStudy\php\php-7.0.12-nts\php.exe vendor\phpunit\phpunit\phpunit --bootstrap tests/TestInit.php tests/EventWorkTest.php D:\phpStudy\php\php-7.0.12-nts\php.exe vendor\phpunit\phpunit\phpunit --bootstrap tests/TestInit.php tests/CronConfigTest.php D:\phpStudy\php\php-7.0.12-nts\php.exe vendor\phpunit\phpunit\phpunit --bootstrap tests/TestInit.php tests/CronTest.php