网络篇06 | 应用层 自定义协议

网络篇06 | 应用层 自定义协议

  • [01 固定协议设计(简化版)](#01 固定协议设计(简化版))
  • [02 可变协议设计(进阶版)](#02 可变协议设计(进阶版))
    • [1)固定头(Fixed Header)](#1)固定头(Fixed Header))
    • [2)可变头(Variable Header)](#2)可变头(Variable Header))
    • 3)消息体(Payload)

其实是参考的TCP的协议报文,mqtt也是参考的tcp的协议报文,具体实现由自己自由发挥即可。

01 固定协议设计(简化版)

1)总体设计

2)值设计

02 可变协议设计(进阶版)

1)固定头(Fixed Header)

messageWay[1--10] 无可变头

1用户端管道激活 2后端管道激活

3用户端消息报文 4后端消息报文

5用户端心跳报文 6后端心跳报文

7用户退出报文 7后端退出报文

9用户异常报文 10后端异常报文

messageType

0平台接收

1在线单用户,本地消息直接发送

2在线全用户,本地消息直接发送,触发广播发送方式

3离线单用户,结合52报文实现

4离线全用户,结合52报文实现

5在线全用户广播消费(和2配套使用)

6在线单用户-定点转发(和1配套使用,如果定点发送失败,需清除错误的redis地址,并丢弃本次消息)

7在线单用户-群发转发(和1配套使用,redis找不到addr,群发后只有消费成功的channel,将对应的addr记录到redis中)

8平台客户端消息踢人下线内部报文

2)可变头(Variable Header)

复制代码
 [1-2]字节,用于存储可变头其他自定义字段的字节长度。
 [3]字节 可变头的版本号,可以支持多个版本
 [4]字节:
       [4]字节 Bit[7-6]为保留字段。

       [4]字节 Bit[5]如果该值为1,表示发送客户端的同时发送一份到服务端,0表示只发送客户端

       [4]字节 Bit[4]如果该值为1,表示如果用户在线则直接发送,0表示下一次用户登录时发送 
       [4]字节 Bit[3]为DUP字段,如果该值为1,表明这个数据包是一条重复的消息;否则该数据包就是第一次发布的消息。 
       [4]字节  Bit[2-1]为Qos字段:Bit1和Bit2为0表示QoS 0:至多一次;Bit1为1表示QoS1:至少一次;Bit2 为1表示QoS 2:只有一次; 
       [4]字节 Bit[0] 是否剔除可变头
  [5-8]字节 离线消息有效时间,单位默认(秒)

3)消息体(Payload)

复制代码
存储形式:byte[]
相关推荐
春眠不觉晓♞3 分钟前
使用多线程快速向Excel中快速插入一万条数据案例
java·学习·excel
FreeBuf_26 分钟前
新型“电力寄生虫“网络钓鱼攻击瞄准能源企业与知名品牌
网络·php·能源
fantasy_431 分钟前
LeetCode238☞除自身以外数组的乘积
java·数据结构·python·算法·leetcode
GalenZhang88833 分钟前
Java生成微信小程序码及小程序短链接
java·微信小程序·小程序
元亓亓亓36 分钟前
Java后端开发day38--不可变集合&Stream流
java·开发语言
纪元A梦44 分钟前
华为OD机试真题——阿里巴巴找黄金宝箱Ⅰ(2025A卷:100分)Java/python/JavaScript/C/C++/GO最佳实现
java·c语言·javascript·c++·python·华为od·go
CHQIUU1 小时前
跨语言哈希一致性:C# 与 Java 的 MD5 之战?
java·c#·哈希算法
JavaDog程序狗1 小时前
【java】easypoi导出excel单元格,填充动态下拉列
java·spring boot·excel
Java中文社群1 小时前
国内首个「混合推理模型」Qwen3深夜开源,盘点它的N种对接方式!
java·人工智能·后端
掉鱼的猫1 小时前
qwen3 惊喜发布,用 ollama + solon ai (java) 尝个鲜
java·openai·deepseek