首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往
您找到你想要的搜索结果了吗?
是的
没有找到

群聊消息“已”“” 功能解决方案!

一朋友和我讨论他前段时间面试某大公司的一题目: 企业IM比如企业微信、钉钉里面的群消息的有个已的功能,发送者刚发出消息时,当前群里其他群成员都是状态,陆陆续续有人看了这个消息,这时候消息的详情变成...x人已,y人,如下图所示,有具体的已列表(万恶的功能,看到同事or老板的消息不能假装没看到了),每条消息对应一个唯一的messageid(uint64_t),每个用户对应一个唯一的userid...(uint64_t),应该如何保存这个消息对应的已详情呢?...仔细分析,按照目前的设计,每一条消息,已详情就要占用8B * 群成员数的内存,如果一个活跃的200人大群,每发一条消息,已就要1600B,如果平均每天消息量是1k,那每个这样的群,每天就要1.6MB...比如C退出群,发消息时maxid还是5,已+总人数应该是3(不包括发消息者本人),目前信息只有5个bit(0/1),识别不出来谁已经退出群聊了 退出群聊的成员如何处理?

2.9K10

面试题:群聊消息的已设计

一朋友和我讨论他前段时间面试某大公司的一题目 : 企业IM比如企业微信、钉钉里面的群消息的有个已的功能,发送者刚发出消息时,当前群里其他群成员都是状态,陆陆续续有人看了这个消息,这时候消息的详情变成...x人已,y人,如下图所示,有具体的已列表(万恶的功能,看到同事or老板的消息不能假装没看到了),每条消息对应一个唯一的messageid(uint64_t),每个用户对应一个唯一的userid...(uint64_t),应该如何保存这个消息对应的已详情呢?...仔细分析,按照目前的设计,每一条消息,已详情就要占用8B * 群成员数的内存,如果一个活跃的200人大群,每发一条消息,已就要1600B,如果平均每天消息量是1k,那每个这样的群,每天就要1.6MB...比如C退出群,发消息时maxid还是5,已+总人数应该是3(不包括发消息者本人),目前信息只有5个bit(0/1),识别不出来谁已经退出群聊了 2、退出群聊的成员如何处理?

1.8K41

钉钉消息咋实现的嘞?

前言 一款app,消息页面有:钱包通知、最近访客等各种通知类别,每个类别可能有新的通知消息,实现已功能,包括多少个,这个是怎么实现的呢?...所有,判断有没有小红点,或者小红点的数字是多少,就是简单的获取你与虚拟人的对话的消息的数量。...当然,一个动作不一定只发一条消息,比如,图中下方有个金刚键"消息",它是所有消息的总和,所以,投递其他消息的时候,也要给它投递一次,不过它只展示一个读数字,所以这个消息只需要一个msg_id即可,不需要消息..."已"。它包含两层意思,一个判否,即内容你是否读过,二是计数,即这个内容有多少人读过。 长尾原因 如果你用Redis存储,成本非常高,浪费非常严重。...这个时候,通常的策略是"[log record]"和"comb", 我们每产生一个动作,比如,赞,收藏,就会产生一个log record( 取关,取消赞...也是一条独立的log record),我们由专门的大数据系统统一收集这些

36310

消息(小红点),前端 与 RabbitMQ 实时消息推送实践,贼简单~

前几天粉丝群里有个小伙伴问过:web 页面的消息(小红点)怎么实现比较简单,刚好本周手头有类似的开发任务,索性就整理出来供小伙伴们参考,没准哪天就能用得上呢。...之前在 《springboot + rabbitmq 做智能家居》 中说过可以用 rabbitmq 的 MQTT 协议做智能家居的指令推送,里边还提到过能用 MQTT 协议做 web 的消息推送,而消息...交换机信息 服务端消息发送 web 端实时消息推送一般都是单向的推送,前端接收服务端推送的消息显示即可,所以就只实现消息发送即可。...message=我是程序员内点事&topic=push_message_topic 模拟发送消息 再看一下前端订阅消息的效果,看到消息被实时推送到了前端,这里只做了消息数量统计,一般还会做消息详情列表...实时消息推送动图 总结 消息是一个十分常见的功能,不管是 web端还是移动端系统都是必备的模块,MQTT 协议只是其中的一种实现方式,还是有必要掌握一种方法。

1.9K10

消息(小红点),前端与 RabbitMQ实时消息推送实践,贼简单~

前几天粉丝群里有个小伙伴问过:web 页面的消息(小红点)怎么实现比较简单,刚好本周手头有类似的开发任务,索性就整理出来供小伙伴们参考,没准哪天就能用得上呢。...之前在 《springboot + rabbitmq 做智能家居》 中说过可以用 rabbitmq 的 MQTT 协议做智能家居的指令推送,里边还提到过能用 MQTT 协议做 web 的消息推送,而消息...[交换机信息] 服务端消息发送 web 端实时消息推送一般都是单向的推送,前端接收服务端推送的消息显示即可,所以就只实现消息发送即可。...message=我是程序员内点事&topic=push_message_topic [模拟发送消息] 再看一下前端订阅消息的效果,看到消息被实时推送到了前端,这里只做了消息数量统计,一般还会做消息详情列表...[实时消息推送动图] 总结 消息是一个十分常见的功能,不管是 web端还是移动端系统都是必备的模块,MQTT 协议只是其中的一种实现方式,还是有必要掌握一种方法。

2.6K109

面试官:群聊消息的已功能,你来设计一个?

小猿学习笔记 来源 | https://www.toutiao.com/i6686735232772604429 一朋友和我讨论他前段时间面试某大公司的一题目 : 企业IM比如企业微信、钉钉里面的群消息的有个已的功能...,发送者刚发出消息时,当前群里其他群成员都是状态,陆陆续续有人看了这个消息,这时候消息的详情变成x人已,y人,如下图所示,有具体的已列表(万恶的功能,看到同事or老板的消息不能假装没看到了...),每条消息对应一个唯一的messageid(uint64_t),每个用户对应一个唯一的userid(uint64_t),应该如何保存这个消息对应的已详情呢?...仔细分析,按照目前的设计,每一条消息,已详情就要占用8B * 群成员数的内存,如果一个活跃的200人大群,每发一条消息,已就要1600B,如果平均每天消息量是1k,那每个这样的群,每天就要1.6MB...比如C退出群,发消息时maxid还是5,已+总人数应该是3(不包括发消息者本人),目前信息只有5个bit(0/1),识别不出来谁已经退出群聊了 退出群聊的成员如何处理?

1.4K40

WEBIM计数不对?

确认是否开启自动已读上报,Server默认删除消息,切换终端、杀进程和退出登录读数会被清除,如果需要保留可以禁用已读上报disableAutoReport。...离线消息读数统计是根据离线消息进行统计,而离线消息有容量限制,如果容量超过会删掉老的消息,平均存储100条消息左右,消息内容越多,存储的越少。...web端计数统计 ALL ON ONE 的原则,一开始登录的第一条最近联系人的会话是不显示计数的 群计数初始值 web端群消息计数初始是通过最近联系人接口返回 登录成功后收到的群消息计数做加一的处理...C2C计数初始值 web端的计数是先获取到最近联系人的所有会话,然后sdk里面会将getmsg里面返回的消息对应之前的会话来做加一处理用来统计消息数 统计之后的计数用webim.MsgStore.sessMap...()i.unread()去显示 登录之后的计数根据消息监听做加一处理 //初始化最近会话的消息读数 function initUnreadMsgCount(){ var sess;

1.5K50

史上最详细仿QQ消息拖拽粘性效果的实现

好久没写文章了,前段时间由于项目代码重构忙了一段时间,现在终于有点时间了就为大家带来一篇关于动画学习的自定义View:类似QQ消息拖拽的效果。...currentRadiusStart; private float currentRadiusEnd; private Rect textRect = new Rect(); //消息数...模拟器显示效果不是很好,真机效果很好看哦 我们可以继续完善一下,在圆中间添加数字实现消息效果 @Override protected void onDraw(Canvas canvas)...带数字消息的效果 追求完美的人看到这里肯定会说消失的时候少个动画,对,QQ上消失的时候有个气泡破裂的感觉,这个用几张不同状态的图,加上帧动画顺序播放就可以实现,由于我这没有图片资源就不演示这个了,帧动画的写法比属性动画简单多了哦...当用户触摸到view的时候把view从当前布局中移除,使用windowManage去addView(view)把我们的可拖拽View添加到window层,铺满屏幕,注意初始位置定位即可实现 2、在显示消息数的地方放置一个圆形的

77820

消息之点不完的小红点(Node+Websocket)

离线用户 在线用户 在线用户且进入群组的用户 离线用户 这种场景就相当于我们退出微信,但是别人在房间里发的消息,当我们再次打开的时候依然能够看到房间增长的消息。...在线用户 这种场景就是相当我们停留在聊天列表页面,当他人在房间中发送消息,我们能够实时的看到消息的条数在增长。 场景示例。 ?...在线用户且在房间的用户 这种场景其实就比较普通了,当别人发送新的消息,我们就能实时看到,此时是不需要标记消息的。 场景示例。 ?...存储在Redis中的消息列表 C. 存储在MongoDB中的消息列表 用户1进入首页。 用户1进入房间,重置用户在房间1的消息,触发更新模块去更新B消息列表。...否,若用户不在房间中,更新其的消息计数 从缓存中获取用户的消息进行分发。 用户2登录我们的项目,从离线用户变成了在线用户。 用户2登录时,触发查询模块,去获取其当前在各个房间消息情况。

2.2K30

IM群聊消息的已功能在存储空间方面的实现思路探讨

如果你对IM中的已功能有产品方面的痛点困惑,可以参考一下微信对已功能的设计定位,详见《IM热门功能思考:为什么微信里没有消息“已”功能?》。...下面是大致的逻辑流程图:  4.2 查询消息人数(私聊、群聊通用) 消息的发送者,加载消息列表到聊天窗口时,可能需要展示消息是否被已。...对群聊而言,显示的信息可能是n人提示,那么需要向服务端查询消息人数,由于客户端可能在UI显示自己发出的多条消息,需支持一次请求查询多条消息。...就像下面这样: 1)对于私聊:如果人数n>0,表示消息; 2)对于群聊:直接显示n人即可,当然,当n等于0时表示全部已。...4.3 查询群消息的已人员清单(群聊) 当客户端希望显示某一条群聊消息的已人员列表,需向服务端发起查询。

5.3K50
领券