Files
mqtt-car/docs/update.md

91 lines
4.1 KiB
Markdown
Raw Normal View History

2025-12-08 10:40:43 +08:00
# 升级指南
**mica-mqtt** 尽量减少对 api 的改动已保证老版本的平滑升级,但是有些大版本不得不改动。希望此文档对大家有所帮助。
## 迁移到 mica-mqtt 2.4.2
注意2.4.2 将 MqttServerCustomizer 和 MqttClientCustomizer 抽到 mica-mqtt-server、mica-mqtt-client。Spring Boot 和 Solon 插入如果有使用到请先将老的包导入删除idea 会自动引入新的包。
**客户端替换包导入:**
- 替换成 `import org.dromara.mica.mqtt.core.client.MqttClientCustomizer;`
**服务端替换包导入:**
- 替换成 `import org.dromara.mica.mqtt.core.server.MqttServerCustomizer;`
## 迁移到 mica-mqtt 2.4.x 以上版本
- :truck: 调整 maven groupId `net.dreamlu` 到新的 `org.dromara.mica-mqtt`
- :truck: 调整包名 `net.dreamlu.iot.mqtt` 到新的 `org.dromara.mica.mqtt`,其他均保持不变。
- :truck: 切换到 central sonatypecentral sonatype 不支持快照版mica-mqtt 不再发布快照版。
## 迁移到 mica-mqtt 2.1.x
- `mica-mqtt-core` 拆分成了 `mica-mqtt-client``mica-mqtt-server`,避免一些依赖引用问题。
- `ByteBufferUtil``org.dromara.mica.mqtt.codec.ByteBufferUtil` 移动到了 `org.tio.utils.buffer.ByteBufferUtil`
- `HexUtil``org.dromara.mica.mqtt.core.util.HexUtil` 移动到了 `org.tio.utils.mica.HexUtils`
### 1. 客户端
#### 1.1 订阅回调接口调整
注意:`mica-mqtt-client-spring-boot-starter` 使用注解订阅可以直升。
`IMqttClientMessageListener#onMessage(ChannelContext context, String topic, MqttPublishMessage message, ByteBuffer payload)` 方法统一添加 `context``message` 参数。
订阅系列方法需要调整:
```java
// 消息订阅,同类方法 subxxx
client.subQos0("/test/#", (context, topic, message, payload) -> {
logger.info(topic + '\t' + ByteBufferUtil.toString(payload));
});
```
#### 1.2 SSL 双向认证支持
```yaml
mica:
client:
ssl:
enabled: false # 是否开启 ssl 认证2.1.0 开始支持双向认证
keystore-path: # 可选参数ssl 双向认证 keystore 目录,支持 classpath:/ 路径。
keystore-pass: # 可选参数ssl 双向认证 keystore 密码
truststore-path: # 可选参数ssl 双向认证 truststore 目录,支持 classpath:/ 路径。
truststore-pass: # 可选参数ssl 双向认证 truststore 密码
```
注意: ssl 存在三种情况
| 服务端开启ssl | 客户端 |
| ---------------------------------------- | --------------------------------------------- |
| ClientAuth 为 NONE不需要客户端验证 | 仅仅需要开启 ssl 即可不用配置证书 |
| ClientAuth 为 OPTIONAL与客户端协商 | 需开启 ssl 并且配置 truststore 证书 |
| ClientAuth 为 REQUIRE (必须的客户端验证) | 需开启 ssl 并且配置 truststore、 keystore证书 |
### 2. 服务端
#### 2.1 IMqttMessageListener 调整
`IMqttMessageListener` onMessage 参数也做了调整,添加了 topic、qoSmessage 改为了原始 MqttPublishMessage方便自行获取 mqtt5.x 的属性。
```java
/**
* 监听到消息
*
* @param context ChannelContext
* @param clientId clientId
* @param topic topic
* @param qoS MqttQoS
* @param message Message
*/
void onMessage(ChannelContext context, String clientId, String topic, MqttQoS qoS, MqttPublishMessage message);
```
#### 2.2 ssl 双向认证支持
```yaml
mica:
server:
ssl: # mqtt tcp ssl 认证
enabled: false # 是否开启 ssl 认证2.1.0 开始支持双向认证
keystore-path: # 必须参数ssl keystore 目录,支持 classpath:/ 路径。
keystore-pass: # 必选参数ssl keystore 密码
truststore-path: # 可选参数ssl 双向认证 truststore 目录,支持 classpath:/ 路径。
truststore-pass: # 可选参数ssl 双向认证 truststore 密码
client-auth: none # 是否需要客户端认证双向认证默认NONE不需要
```