我们平时在使用即时通讯应用时候,每当发出一条聊天消息,都希望对方尽快看到,并尽快回复,但对方到底有没有真的看到?我却并不知道。
一个残酷的现实是,很多时候对方其实是早就已经看到了这条消息,但出出种种原因(大家都懂的),通常都是默默返回——假装没看见。

群消息怎么设计?
大家一起跟着楼主的节奏,一步一步来看群消息怎么设计。
核心问题1:群消息,只存一份?还是,每个成员存一份?
答:存一份,为每个成员设置一个群消息队列,会有大量数据冗余,并不合适。
核心问题2:如果群消息只存一份,怎么知道每个成员读了哪些消息?
答:可以利用群消息的偏序关系,记录每个成员的last_ack_msgid(last_ack_time),这条消息之前的消息已读,这条消息之后的消息未读。该方案意味着,对于群内的每一个用户,只需要记录一个值即可。
解答上述两个核心问题后,很容易得到群消息的核心数据结构。
群消息表:记录群消息
group_msgs(msgid, gid, sender_uid, time, content);
各字段的含义为:消息ID,群ID,发送方UID,发送时间,发送内容。
群成员表:记录群里的成员,以及每个成员收到的最后一条群消息
group_users(gid, uid, last_ack_msgid);
各字段的含义为:群ID,群成员UID,群成员最后收到的一条群消息ID。
了解一下群消息发送的流程
业务场景:</

本文探讨了即时通讯中群聊消息的已读回执功能设计,包括群消息存储、成员状态跟踪、消息推送流程以及已读回执的实现。通过消息回执表记录已读未读状态,并提出消息批量ack和已读回执拉取优化策略,以减少消息风暴扩散系数和存储需求。
最低0.47元/天 解锁文章
1312

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



