jeanile / hyperf-taobao-tmc
taobao sdk tmc
v1.0.0
2024-06-07 10:38 UTC
Requires
- php: >=7.4
- ext-json: *
- hyperf/contract: ~2.2.0
- hyperf/event: ~2.2.0
- hyperf/framework: ~2.2.0
- hyperf/logger: ~2.2.0
- hyperf/utils: ~2.2.0
- hyperf/websocket-client: ~2.2.0
Requires (Dev)
- friendsofphp/php-cs-fixer: ^3.0
- mockery/mockery: ^1.0
- phpstan/phpstan: ^1.0
- phpunit/phpunit: >=7.0
- swoole/ide-helper: ^4.5
This package is auto-updated.
Last update: 2025-03-07 12:06:16 UTC
README
淘宝消息服务 TMC 的 PHP 版本,是基于 Hyperf 框架实现。
特性
- 基于 hyperf 框架
- 使用 swoole 的 websocket client 实现
- 可配置化
- 支持多应用多店铺
- 自动重连
- 心跳维持
使用要求
- PHP 7.4+
- Swoole 4.4LTS+
- Hyperf 2.2+
安装
1. Composer安装
composer require jeanile/hyperf-taobao-tmc
2. 发布配置文件
php bin/hyperf.php vendor:publish jeanile/hyperf-taobao-tmc
配置参数说明:
配置项 | 类型 | 说明 | 默认值 |
---|---|---|---|
enable | bool | 消息回调开关 | true |
uri | string | 淘宝 ws 链接 | ws://mc.api.taobao.com |
app_key | string | 应用 app_key | 30 |
app_secret | string | 应用 app_secret | 30 |
group_name | string | 分组名,目前仅支持默认分组 | default |
options.reconnect_time | int | 每隔n秒执行重连检查 | 15(秒) |
options.pull_request_time | int | 每隔n秒主动请求维持连接 | 60(秒) |
service_name | string | 店铺唯一标识,可用 app_key 或自定义 | |
handler | string | 消息处理类 |
多个店铺配置:
<?php declare(strict_types=1); return [ 'enable' => true, 'conn' => [ '官方旗舰店' => [ 'uri' => env('TMC_URI'), 'app_key' => env('TIANMAO_APP_KEY'), 'app_secret' => env('TIANMAO_APP_SECRET'), 'group_name' => 'default', 'options' => [ 'reconnect_time' => 15, 'pull_request_time' => 60, ], 'service_name' => 'shop_unique_id1', 'handler' => \App\Notify\TMCMessageHandler::class, ], '海外旗舰店' => [ 'uri' => env('TMC_URI'), 'app_key' => env('TIANMAO_APP_KEY'), 'app_secret' => env('TIANMAO_APP_SECRET'), 'group_name' => 'default', 'options' => [ 'reconnect_time' => 15, 'pull_request_time' => 60, ], 'service_name' => 'shop_unique_id2', 'handler' => \App\Notify\TMCMessageHandler::class, ], ], ];
使用
创建一个 handle 类,并实现 MessageHandlerInterface
<?php declare(strict_types=1); namespace App\Notify; use Hyperf\Contract\StdoutLoggerInterface; use JeaNile\HyperfTaobaoTmc\Handler\MessageHandlerInterface; use JeaNile\HyperfTaobaoTmc\Message\Message; use Psr\Container\ContainerInterface; class TMCMessageHandler implements MessageHandlerInterface { protected ContainerInterface $container; protected StdoutLoggerInterface $logger; public function __construct(ContainerInterface $container) { $this->logger = $container->get(StdoutLoggerInterface::class); } public function handle(string $serviceName, Message $resMsg): void { $this->logger->info(sprintf('shop:%s:resMsg:%s', $serviceName, $resMsg->toString())); // 业务处理 } }
注意事项
项目部署在多个台服务器(pod)上时会建立多个连接,但消息只会被一台机器消费了,因此如果区分多个环境,如:测试、预发布、生产环境,建议上线后仅生产环境开启(enable 设置 true),其他环境关闭,避免抢占消费消息。
TODO
- 支持多环境接收消息开关(如:测试环境也能开启但仅接收不发送 ACK)
- 支持分组
- 店铺按独立进程隔离