# 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