介绍
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应答包仅仅是用来确认消息接收,因此其数据结构应尽量精简,除了流程中需要用到的字段,其他可选的字段都可省略,以提高网络传输的效率。
ACK机制是即时通讯中确保消息可靠投递的关键,通过接收方回传ACK应答包来确认消息接收。当发送方未收到ACK时,会进行重试,直到达到预设的重试上限。此流程包括A(客户端)发送消息给S(服务端),S转发给B(客户端)并各自返回ACK。数据结构设计简洁,仅包含必要的id和type字段以提高效率。
645

被折叠的 条评论
为什么被折叠?



