IM即时通信软件设计
参考资料:
- 架构篇:https://yq.aliyun.com/articles/698301
- 模型篇:https://yq.aliyun.com/articles/701593
- 实现篇:https://yq.aliyun.com/articles/710363
架构设计
存储模型设计
群主场景的优化
对于群组的场景,有必要将一个消息放入群里的每个成员的收件箱timeline吗?感觉没必要啊,要是群成员很多,那将群消息同步到所有群成员的收件箱很耗时,性能很差。合理的方法应该是对于群组的场景,不需要将群消息同步到所有群成员的收件箱了,而是改为通知所有群成员某个群的会话有新消息,让所有群成员的设备都到群会话对应的timeline拉取消息就行了。
如何支持消息撤回?
撤回消息,用户的本意应该是希望撤销这条消息。对于服务端来说,正确的逻辑应该是删除这个消息。我的初步考虑是,写入一条撤回消息到timeline。读取timeline时,做一下消息过滤,某个消息出现了对应的撤回消息,则不返回给设备端即可。大家也可以抛出自己的想法。
正文到此结束