介绍
ACK(Acknowledgement)机制,即确认机制。在即时通讯开发领域,ACK机制是为了应对复杂多变的网络环境,确保消息的可靠投递而设计的。
这套机制的核心,是接收方在成功收到消息并正确处理后,需要回复给发送方一个确认应答数据包(ACK应答包),用来表示消息已确认接收无误。
失败重试
发送方通常需要在本地维护一个等待ACK的队列,如果在一定时间内未收到指定消息对应的ACK应答包,则会尝试重新发送当前的消息。
一般会设置一个重试次数的上限,达到此上限之后就不再发送,转而在客户端显示发送失败的提醒。
发送失败流程
以A、B分别代表客户端,S代表服务端,整个ACK机制的流程大致如下:
- A发送消息给B,实际上是投递给了S ,S成功收到后需要返回ACK应答包给A ;
- S将消息转发给B, B成功收到并持久化到本地后,需要返回ACK应答包给S 。
数据结构设计
{
"id": 399234112,
"type": 1
}
参数定义:
参数名 | 数据类型 | 参数含义 |
---|---|---|
id | Long | 数据包id,与发送方所发消息的数据包id对应 |
type | Integer | 数据包类型,此处标识为ACK类型 |
ACK应答包仅仅是用来确认消息接收,因此其数据结构应尽量精简,除了流程中需要用到的字段,其他可选的字段都可省略,以提高网络传输的效率。
网友评论