IM即时通讯设计技术点总结

与传统的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)

群组

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值