标记已读

单聊

  • 发送方发送一条消息
  • 服务端消息入库,检查接收方在线状态。若在线,推送;不在线,接收方登录时拉取
  • 接收方收到消息,发送已读回执
  • 服务端收到回执并入库,通知发送方
  • 发送方更新本地数据库,修改已读状态

群聊

群消息投递流程,以及可达性保证

核心问题
  • 群消息,只存一份?还是,每个成员存一份?
    存一份
  • 如果群消息只存一份,怎么知道每个成员读了哪些消息?
    记录每个成员的last_ack_msgid
  • 如何保证接收方一定收到群消息?
    各个群成员收到消息后,要修改各群成员的last_ack_msgid,以告诉系统,这一条消息确认收到了
  • 如果ack丢失,群友会不会拉取重复的群消息?
    会,可以根据msgid在客户端本地做去重
核心数据结构
  • 群消息表:记录群消息。
    group_msgs(msgid, gid, sender_uid, time, content);
    各字段的含义为:消息ID,群ID,发送方UID,发送时间,发送内容。
  • 群成员表:记录群里的成员,以及每个成员收到的最后一条群消息。
    group_users(gid, uid, last_ack_msgid);
    各字段的含义为:群ID,群成员UID,群成员最后收到的一条群消息ID。
群消息发送的流程
群消息发送的流程
  • A发出群消息
  • server收到消息后,一来要将群消息落地,二来要查询群里有哪些群成员,以便实施推送
  • 对于群成员,查询在线状态
  • 对于在线的群成员,实施推送
群消息确认流程
在线成员

离线成员

已读回执流程

对于发送方发送的任何一条群消息,都需要知道,这条消息有多少人已读多少人未读,就需要一个基础表来记录这个关系。

消息回执表:用来记录消息的已读回执。

msg_acks(sender_uid, msgid, recv_uid, gid, if_ack);
各字段的含义为:发送方UID,消息ID,回执方UID,群ID,回执标记。

群消息流程
消息流程
  • 将群消息入库
  • 查询群里有哪些群成员,以便实施推送
  • 插入每条消息的初始回执状态


    发送方已读回执
  • 发送ack请求
  • 修改last_ack_msgid,并且,修改已读回执if_ack状态
  • 查询发送方在线状态
  • 向发送方实时推送已读回执(如果发送方在线)
  • 如果发送方不在线,ta会在下次登录的时候,从关联表里拉取每条消息的已读回执

流程优化方案

群消息已读回执的“消息风暴扩散系数”

假设每个群有200个用户,其中20%的用户在线,即40各用户在线。群用户每发送一条群消息,会有:

  • 40个消息,通知给群友
  • 40个ack修改last_ack_msgid,发给服务端
  • 40个已读回执,通知给发送方
  • 需要存储40条ack记录
优化方案
  • 群消息的推送,能否改为接收方轮询拉取?
    答:不能,消息接收,实时性是核心指标。
  • 对于last_ack_msgid的修改,真的需要每个群消息都进行ack么?
    答:其实不需要,可以批量ack。有副作用(不实时,拉取重复消息)
  • 发送方在线时,对于已读回执的发送,真的需要实时推送么?
    答:其实不需要,发送方每发一条消息,会收到40个已读回执,采用轮询拉取或放入keepalive请求里。副作用是不实时。

原文:https://mp.weixin.qq.com/s/fQhmrrJ0jypm_O3WFs7ftw

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 212,332评论 6 493
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,508评论 3 385
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 157,812评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,607评论 1 284
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,728评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 49,919评论 1 290
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,071评论 3 410
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,802评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,256评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,576评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,712评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,389评论 4 332
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,032评论 3 316
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,798评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,026评论 1 266
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,473评论 2 360
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,606评论 2 350