# Mqtt
[TOC]
SD提供了MQTT异步客户端。
* 异步MQTT客户端,可以结合EMQ开源服务器实现百万千万级通讯业务。
* 支持完整的MQTT协议规则
* 纯异步,断线重连
## 创建MQTT连接
```php
public function initAsynPools($workerId)
{
parent::initAsynPools();
$mqtt = new MQTT('tcp://127.0.0.1:11883/','root1');
//设置持久会话
$mqtt->setConnectClean(false);
//认证
$mqtt->setAuth('root1','root');
//存活时间
$mqtt->setKeepalive(3600);
//回调
$mqtt->on('publish', function ($mqtt, PUBLISH $publish_object) {
printf(
"\e[32mI got a message\e[0m:(msgid=%d, QoS=%d, dup=%d, topic=%s) \e[32m%s\e[0m\n",
$publish_object->getMsgID(),
$publish_object->getQos(),
$publish_object->getDup(),
$publish_object->getTopic(),
$publish_object->getMessage()
);
});
$mqtt->on('connack', function (MQTT $mqtt, CONNACK $connack_object) {
var_dump("MQTT连接成功");
$topics['$SYS/#'] = 1;
$mqtt->subscribe($topics);
});
$mqtt->connect();
}
```
>我们在initAsynPools中创建了Mqtt客户端,这样会导致每个worker进程都会创建一个MQTT客户端。
最好的做法是创建一个自定义进程,在自定义进程中创建MQTT客户端。
MQTT是纯异步的,需要通过回调获取通讯的结果。
## 回调
* connack 连接成功的回调
* disconnect 断开连接的回调
* puback
* pubrec
* pubrel
* pubcomp
* suback 订阅成功的回调
* unsuback 移除订阅的回调
* publish 收到订阅消息的回调
## Api
* setRetryTimeout 设置Retry超时时间
* setVersion 设置MQTT版本
* version 获取MQTT版本
* setAuth 设置AUTH
* setKeepalive 设置Keepalive时间
* setConnectClean 设置连接清除标志
* setWill 设置遗嘱消息
* on 设置回调
* ping ping
* connect 连接
* disconnect 断开连接
* publish 发布
* subscribe 订阅
* unsubscribe 取消订阅
- SD3.X简介
- 捐赠SD项目
- VIP服务
- 基础篇
- 搭建环境
- 使用Composer安装/更新SD框架
- 启动命令
- 开发注意事项
- 框架配置
- 配置文件夹
- server.php
- ports.php
- business.php
- mysql.php
- redis.php
- timerTask.php
- log.php
- consul.php
- catCache.php
- client.php
- 自定义配置
- 框架入口
- MVC架构
- 加载器-Loader
- 控制器-Controller
- 模型-Model
- 视图-View
- 同步任务-Task
- 封装器
- Swoole编程指南-EOF协议
- Swoole编程指南-固定包头协议
- 封装器-Pack
- 路由器
- TCP相关
- 绑定UID
- Send系列
- Sub/Pub
- 获取服务器信息
- Http相关
- HttpInput
- HttpOutput
- 默认路由规则
- WebSocket相关
- 使用SSL
- 公共函数
- 进阶篇
- 内核优化
- 封装器路由器原理剖析
- 对象池
- 上下文-Context
- 中间件
- 进程管理
- 创建自定义进程
- 进程间RPC
- 自定义进程如何使用连接池
- 异步连接池
- Redis
- Mysql
- Mqtt
- HttpClient
- Client
- AMQP
- RPC
- 日志工具-GrayLog
- 微服务-Consul
- Consul基础
- 搭建Consul服务器
- SD中Consul配置
- 微服务
- 选举-Leader
- Consul动态配置定时任务
- 熔断与降级
- 集群-Cluster
- 高速缓存-CatCache
- 万物-Actor
- Actor原型
- Actor的创建
- Actor间的通讯
- 消息派发-EventDispatcher
- 延迟队列-TimerCallBack
- 协程
- 订阅与发布
- MQTT简易服务器
- AMQP异步任务调度
- 自定义命令-Console
- 调试工具Channel
- 特别注意事项
- 日常问题总结
- 实践案例
- 物联网自定义协议
- Actor在游戏的应用
- Mongodb以及一些同步扩展的使用
- 自定义进程使用MQTT客户端
- 开发者工具
- SDHelper