与传统的c/s、b/s架构不同,IM架构是c/s/c架构的;IM系统最重要的指标就是实时性、可靠性。
如何保证消息的可靠投递
ack响应机制,超时、重传、确认、去重的机制保证消息的可靠投递;
在线、离线消息处理机制
先存储消息,然后判断接收人在线离线,
如果接收人在线,直接长连接发送;
如果接收人离线,则直接走push通知提醒,待接收人上线时,再拉取离线消息;
消息已读未读状态
(1)扩散写方式:
直接更新消息表中的read_status;
(2)扩散读方式:
根据ack回执更新消息状态表,并更新群-成员关系中的last_ack_msgid;
IM群聊消息:扩散读、扩散写
扩散写(存多份):
发送人发送一条群消息到server,服务器按照群成员拆分成多条消息存储并转发。
群组 group(gid, gname)
群组-成员关系 group_member(gid, uid)
群组