美文网首页
IMI每日一概念IACK机制

IMI每日一概念IACK机制

作者: 星际码仔 | 来源:发表于2021-10-31 21:55 被阅读0次

    介绍

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

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

    失败重试

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

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

    发送失败

    流程

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

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

    数据结构设计

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

    参数定义:

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

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

    相关文章

      网友评论

          本文标题:IMI每日一概念IACK机制

          本文链接:https://www.haomeiwen.com/subject/bodaaltx.html