IMI每日一概念IACK机制

介绍

ACK(Acknowledgement)机制,即确认机制。在即时通讯开发领域,ACK机制是为了应对复杂多变的网络环境,确保消息的可靠投递而设计的。

这套机制的核心,是接收方在成功收到消息并正确处理后,需要回复给发送方一个确认应答数据包(ACK应答包),用来表示消息已确认接收无误。

失败重试

发送方通常需要在本地维护一个等待ACK的队列,如果在一定时间内未收到指定消息对应的ACK应答包,则会尝试重新发送当前的消息

一般会设置一个重试次数的上限,达到此上限之后就不再发送,转而在客户端显示发送失败的提醒。

微信图片_20211031215033.jpg

流程

以A、B分别代表客户端,S代表服务端,整个ACK机制的流程大致如下:

  1. A发送消息给B,实际上是投递给了S ,S成功收到后需要返回ACK应答包给A ;
  2. S将消息转发给B, B成功收到并持久化到本地后,需要返回ACK应答包给S 。

ACK机制.png

数据结构设计

{
    
    
  "id": 399234112,
  "type": 1
}

参数定义:

参数名 数据类型 参数含义
id Long 数据包id,与发送方所发消息的数据包id对应
type Integer 数据包类型,此处标识为ACK类型

ACK应答包仅仅是用来确认消息接收,因此其数据结构应尽量精简,除了流程中需要用到的字段,其他可选的字段都可省略,以提高网络传输的效率。

猜你喜欢

转载自blog.csdn.net/Alfred_C/article/details/121071254