https://github.com/hyperf/mqtt-server-incubator
https://github.com/hyperf/mqtt-server-incubator
Last synced: 10 months ago
JSON representation
- Host: GitHub
- URL: https://github.com/hyperf/mqtt-server-incubator
- Owner: hyperf
- License: mit
- Created: 2021-04-16T08:00:57.000Z (almost 5 years ago)
- Default Branch: main
- Last Pushed: 2023-11-06T06:09:23.000Z (about 2 years ago)
- Last Synced: 2024-09-24T21:55:33.292Z (over 1 year ago)
- Language: PHP
- Size: 63.5 KB
- Stars: 18
- Watchers: 5
- Forks: 5
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# MQTT Server
## 安装
```bash
composer require hyperf/mqtt-server-incubator
```
## 配置服务
```php
SWOOLE_BASE,
'servers' => [
[
'name' => 'mqtt',
'type' => Server::SERVER_BASE,
'host' => '0.0.0.0',
'port' => 1883,
'sock_type' => SWOOLE_SOCK_TCP,
'callbacks' => [
Event::ON_RECEIVE => [Hyperf\MqttServer\MQTTServer::class, 'onReceive'],
],
],
],
'settings' => [
'enable_coroutine' => true,
'worker_num' => 4,
'pid_file' => BASE_PATH . '/runtime/hyperf.pid',
'open_tcp_nodelay' => true,
'max_coroutine' => 100000,
'open_http2_protocol' => true,
'max_request' => 0,
'socket_buffer_size' => 2 * 1024 * 1024,
'package_max_length' => 2 * 1024 * 1024,
],
'callbacks' => [
Event::ON_BEFORE_START => [Hyperf\Framework\Bootstrap\ServerStartCallback::class, 'beforeStart'],
Event::ON_WORKER_START => [Hyperf\Framework\Bootstrap\WorkerStartCallback::class, 'onWorkerStart'],
Event::ON_PIPE_MESSAGE => [Hyperf\Framework\Bootstrap\PipeMessageCallback::class, 'onPipeMessage'],
Event::ON_WORKER_EXIT => [Hyperf\Framework\Bootstrap\WorkerExitCallback::class, 'onWorkerExit'],
],
];
```
启动服务,我们就可以简单的使用 MQTT 服务了。
## 自定义事件
组件增加了可以监听 MQTT 服务各个阶段的事件,比如我们写一个 `MQTTConnectHandler` 用来监听客户端连接。
> PUBLISH, SUBSCRIBE 和 UNSUBSCRIBE 三个事件,需要自行实现
```php
getBody());
return $response;
}
}
```
重启服务,连接 MQTT 时,便可以得到以下输出。
```
$ php bin/hyperf.php start
[INFO] TCP Server listening at 0.0.0.0:1883
string(234) "{"type":1,"protocol_name":"MQTT","protocol_level":4,"clean_session":1,"will":{"qos":0,"retain":0,"topic":"simps-mqtt\/user001\/delete","message":"byebye"},"user_name":"","password":"","keep_alive":10,"client_id":"Simps_60e5aa0c4284f"}"
```
组件支持的事件列表如下:
| 事件 | 备注 |
| :-------------: | :------------------: |
| MQTTConnect | 客户端连接时触发 |
| MQTTDisconnect | 客户端断开连接时触发 |
| MQTTPingReq | |
| MQTTPublish | 客户端发布消息时触发 |
| MQTTSubscribe | 客户端订阅时触发 |
| MQTTUnsubscribe | 客户端取消订阅时触发 |
注解支持参数如下
| 参数 | 备注 |
| :------: | :--------------------------------------------: |
| server | 指定当前事件对应的服务名 |
| type | 事件类型 |
| priority | 事件优先级,越大越先执行,默认的事件优先级为 0 |