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

其实是参考的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
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值