首页
学习
活动
专区
工具
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),识别不出来谁已经退出群聊了 退出群聊的成员如何处理?

3.1K10

钉钉消息、未咋实现的嘞?

前言 一款app,消息页面有:钱包通知、最近访客等各种通知类别,每个类别可能有新的通知消息,实现已、未功能,包括多少个未,这个是怎么实现的呢?...所有,判断有没有小红点,或者小红点的数字是多少,就是简单的获取你与虚拟人的对话的未消息的数量。...当然,一个动作不一定只发一条消息,比如,图中下方有个金刚键"消息",它是所有消息的总和,所以,投递其他消息的时候,也要给它投递一次,不过它只展示一个未读数字,所以这个消息只需要一个msg_id即可,不需要消息...厂商也有专门针对这类场景的存储产品。大多数情况,我们只需要一个数量,固定从maximal_id往前取,如果取到100条还没完,直接返回99+完事了。..."和未"。它包含两层意思,一个判否,即内容你是否读过,二是计数,即这个内容有多少人读过。 长尾原因 如果你用Redis存储,成本非常高,浪费非常严重。

47210
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    面试题:群聊消息设计

    一朋友和我讨论他前段时间面试某大公司的一题目 : 企业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.9K41

    消息队列-腾讯消息队列 CKafka

    腾讯消息队列 CKafka,分布式、高吞吐量、高可扩展性的消息服务,100%兼容开源 Apache Kafka 0.9 0.10 腾讯消息队列 CKafka点击查看详情 消息队列 CKafka 简介...腾讯消息队列 CKafka 的特性 兼容开源 100% 兼容 Apache Kafka 0.9 0.10版本,迁移上0成本。...上下游生态 支持与 EMR、COS、容器、流计算、无服务器函数、日志服务等13+上产品打通,实现快速一键部署。...高可靠 消息队列 CKafka 集群性能强劲,生产性超越开源方案;此外,消息队列 CKafka 分布式的部署,集群稳定性也有很好的保障。...统一运维监控 提供腾讯平台整套的运维服务,包括租户隔离、权限控制、消息堆积查询、消费者详情查看等多维度监控告警等运维服务。

    6K60

    IM群聊消息回执功能该怎么实现?

    更有甚者,钉钉的群聊“强制回执”功能,甚至能够知道谁读了消息,谁没有消息(老板的福音啊)。 那么群聊消息的收发流程、消息的送达保证、回执机制,到底该怎么实现呢?这就是今天要讨论的话题。...对于发送方发送的任何一条群消息,都需要知道,这条消息有多少人多少人未,就需要一个基础表来记录这个关系。...7、回执流程优化方案 再次详细的分析下,群消息回执的“消息风暴扩散系数”,假设每个群有200个用户,其中20%的用户在线,即40各用户在线。...8、本文小结 对于群消息回执,一般来说: 如果发送方在线,会实时被推送回执; 如果发送方不在线,会在下次在线时拉取回执。...如果要对进行优化,可以: 接收方累计收到N条群消息再批量ack; 发送方轮询拉取回执。 物理删除回执数据,定时删除或归档非核心历史数据。

    4.9K20

    低代码智能通信腾讯短信助力,快速构建高效消息应用

    在此背景下,短信作为一种成熟、稳定且广泛应用的通信手段,因其快速、直接和可靠的特点,仍然保持着不可替代的作用。...环境准备 活字格设计器 活字格服务器 对接步骤 1.获取SecretId和SecretKey (1)进入腾讯用户管理,新建用户。...待签名与正文模板状态变为通过时才可用。 5.获取SMS SDKAppId 在应用管理-应用列表页面,点击“创建应用”,获取新应用的SDKAppID。...6.活字格服务端命令对接发送短信 在活字格设计器中创建服务端命令,选择【腾讯发送短信】命令。...7.实现效果 更多关于【腾讯发送短信】命令插件可以参考这篇文章。 总结 引入发送短信功能是提升服务质量、增强用户体验、保障用户安全的重要举措。

    9210

    消息腾讯即时通信IM支持IPv6啦!

    为了让用户在使用即时通信IM(下文简称"IM")中能获得最佳的效果,腾讯IM的 iOS 和 Android系统现已支持 IPv6版本了!...登录腾讯即时通信IM立刻升级体验! ?...腾讯即时通信 IM 提供覆盖全球的高连通、高可靠、强安全的网络连接通道,自研多重最优寻址算法,具有全网调度能力,终端在海外登录时,IM SDK 会访问就近接入点或加速点,是全球化运营企业在通信服务的最佳选择...截至目前,腾讯即时通信 IM 能力覆盖多个行业,让通信随心所想,触达全球。 ? 腾讯通信 一直致力于 让每个企业 都享受智慧服务带来的改变 END 未来可期 ?...长按扫码关注腾讯通信官方微信公众号 以获取更多更专业的通信知识

    4.9K20

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

    ,发送者刚发出消息时,当前群里其他群成员都是未状态,陆陆续续有人看了这个消息,这时候消息的详情变成x人,y人未,如下图所示,有具体的列表(万恶的功能,看到同事or老板的消息不能假装没看到了...),每条消息对应一个唯一的messageid(uint64_t),每个用户对应一个唯一的userid(uint64_t),应该如何保存这个消息对应的详情呢?...仔细分析,按照目前的设计,每一条消息详情就要占用8B * 群成员数的内存,如果一个活跃的200人大群,每发一条消息就要1600B,如果平均每天消息量是1k,那每个这样的群,每天就要1.6MB...{ uint32_t maxid, uint8_t readbit[]} 如上面的案例就是{5, readbit[0] =bin(0000 0000)}; 就占用了5B(4+1),A发消息,D消息时...比如C退出群,发消息时maxid还是5,+未总人数应该是3(不包括发消息者本人),目前信息只有5个bit(0/1),识别不出来谁已经退出群聊了 退出群聊的成员如何处理?

    1.6K40

    腾讯 CMQ 消息队列测试

    队列名称是一个不超过64个字符的字符串,必须以字母为首字符,剩余部分可以包含字母、数字和横划线(-) 进行了简单的测试,队列名称都是符合文档规则 发送消息 batch批量发送消息 消息正文。...表示这一批量中的一条消息。...目前批量消息数量不能超过 16 条 这块有个问题就是:都是编译成功了的 自己写了批量发送消息循环,当发送消息数最大值为1000时候,会直接报异常 当消息数最大值为10000时候,隔了5s左右,报出异常...快速报出exception 在linux服务器上也进行了测试: 接受消息 (BatchReceiveMessage) 用于消费队列中的多条(目前最多16条)消息 在api可以正常获取到 因接受消息时...备注 今天收到腾讯 CMQ 产品经理针对文章里的问题特意发来的邮件回复: 同时谢谢腾讯提供CMQ的内测体验资格!

    13.8K00

    IM热门功能讨论:为什么微信里没有消息”功能?

    1、引言 张小龙说:微信消息不做“”和“未”的功能,是因为要给人撒谎的机会,这才符合人性。 真的对吗? 关于这个问题……对,也不对。...▲ 市面上有很多IM提供了功能,上图从上至下分别为:钉钉、易信、旺旺(千牛) (上图引用自文章《IM群聊消息回执功能该怎么实现?》)...▲ 阿里旺旺的PC端消息”功能 换句话说:聊天消息的“”和“未”状态在什么情况下该做呢? 这是一个典型的功能分析,遇到这种分析,我们应该如何用产品思维入手呢?...3.2 第二步:本源思维:定位+场景 我们先来看看两个网友,对于微信消息为什么没有“”和“未”功能的优质回答。...▲ “抢红包”的牛X之处在于:居然能让面对面的两个人使用IM却不觉乏味 5、补充 本文是从产品角度讨论微信中的消息”功能,如果您对消息”功能的理论和技术实现有兴趣,可以进一步阅读《IM群聊消息回执功能该怎么实现

    1K30

    IM热门功能讨论:为什么微信里没有消息”功能?

    1、引言 张小龙说:微信消息不做“”和“未”的功能,是因为要给人撒谎的机会,这才符合人性。 真的对吗? 关于这个问题……对,也不对。 ? ? ?...▲ 市面上有很多IM提供了功能,上图从左至右分别为:钉钉、易信、旺旺(千牛) (上图引用自文章《IM群聊消息回执功能该怎么实现?》)...▲ 阿里旺旺的PC端消息”功能 换句话说:聊天消息的“”和“未”状态在什么情况下该做呢? 这是一个典型的功能分析,遇到这种分析,我们应该如何用产品思维入手呢?...3.2 第二步:本源思维:定位+场景 我们先来看看两个网友,对于微信消息为什么没有“”和“未”功能的优质回答。...▲ “抢红包”的牛X之处在于:居然能让面对面的两个人使用IM却不觉乏味 5、补充 本文是从产品角度讨论微信中的消息”功能,如果您对消息”功能的理论和技术实现有兴趣,可以进一步阅读《IM群聊消息回执功能该怎么实现

    1.3K20

    消息回执(这个diao),究竟是推还是拉?

    有甚者,钉钉的群有“强制回执”功能,你在群里发出的消息,能够知道谁读了消息,谁没有消息。...二、回执流程 对于发送方发送的任何一条群消息,都需要知道,这条消息有多少人多少人未,就需要一个基础表来记录这个关系。 消息回执表:用来记录消息回执。...(如果发送方在线) 如果发送方不在线,ta会在下次登录的时候: (5)从关联表里拉取每条消息回执 这里的初步结论是: 如果发送方在线,会实时被推送回执 如果发送方不在线,会在下次在线时拉取回执...答:回执数据不是核心数据 消息,可以进行物理删除,而不是标记删除 超过N长时间的回执,归档或者删除掉 四、总结 对于群消息回执,一般来说: 如果发送方在线,会实时被推送回执 如果发送方不在线...,会在下次在线时拉取回执 如果要对进行优化,可以: 接收方累计收到N条群消息再批量ack 发送方轮询拉取回执 物理删除回执数据,定时删除或归档非核心历史数据 推送还是拉取?

    1.5K30

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

    那么,对于状态: 1)如果是私聊:消息的阅读状态比较容易实现,在性能和存储上也不存在问题; 2)如果是群聊:考虑到存储和处理性能,特别当处于一个环境时,如何高效地处理群聊的状态是一个非常值得探讨的话题...4.1 通知消息(私聊、群聊通用) 当小宝阅读了一条或若干条消息,需向服务端发送消息通知:“众爱卿发的x+y+z消息,朕已阅”。...服务端收到小宝的通知时,需完成以下事项: 1)存储消息状态; 2)返回应答给小宝; 3)向列表的消息的原始发送者通知消息。...4.3 查询群消息、未人员清单(群聊) 当客户端希望显示某一条群聊消息、未人员列表,需向服务端发起查询。...这仅仅是一个群在一天之内产生的阅读状态数据,如果是在平台运行,单此功能消耗的空间,呵呵~~ 题外话:如果成员不是用4字节整型存储,而改用字符串,比如"1123356777",那就更可观了。

    5.7K50

    腾讯vpc网络通信原理

    (arping命令是用于测试指定服务器返回他的网卡硬件地址(mac地址)) image.png image.png 首先回复一下在腾讯vpc这应该是正常情况。...否则会向局域网中所有的机器进行广播,有机器应答(b机器)后会将b的机器mac存放在本地的 arp映射表中一份供后续通信使用,这是简单的讲解了以太网工作原理。...腾讯vpc网络通信原理 腾讯的vpc网络默认是关闭广播与组播功能的,这就有别与以太网的工作原理,当然这里也可以开启广播与组播功能,具体开启见(https://cloud.tencent.com/document.../product/215/36526) 在腾讯vpc网络中a连接b机器流程 vm(a)->arp代理-> 桥接 -> 主机 —>虚拟交换机->gre封包 ->腾讯网络 -> gre解包->虚拟交换机...(注:目前了解腾讯 & 阿里vpc都是相同效果即私有网络内arping服务器返回网卡硬件地址(mac地址)都是一样的,华为云和aws的vpc和传统以太网效果类似即arp -a 中可以查到私有网络内其他服务器的网卡硬件地址

    6.9K51

    功能速递 | 全网首家,腾讯即时通信 IM Web 端支持消息搜索啦!

    腾讯即时通信 IM 从更好地满足客户需求,更好地为客户服务的角度出发,经过一年时间的调研、立项、开发、内测,于近日正式上线了 Web 端消息搜索功能 - 云端搜索,是国内外首家提供此项能力的即时通信IM...其流程如下所示: 为了支持 Web 端消息搜索,腾讯即时通信 IM 需要将应用的全量历史消息,和终端用户在应用内发送的实时消息导入消息搜索集群服务。...上述流程要求腾讯即时通信 IM 部署大量的机器、带宽和存储资源,因此此功能并不包含在 IM 基础套餐包内,需要您额外付费购买。...为了节省您的开发时间和成本,腾讯即时通信 IM 提供了精心设计的,UI 精美且开源免费的 UIKit,易于理解和操作,可以让终端用户基于 UIKit 轻松完成搜索过程,快速、准确地找到自己预期的内容。...搜索指定会话内所有文件消息 快来扫码免费体验吧~ 腾讯即时通信Web-IM Demo 功能开通: https://console.cloud.tencent.com/im/plugin/TUICloudSearch

    39020

    重磅消息,首个腾讯行业认证发布!

    为了帮助广大腾讯生态合作伙伴售前架构师角色学习并了解腾讯核心产品:政务专区的技术、产品原理,提高腾讯政务专区解决方案架构能力。...现腾讯产业人才培养中心推出腾讯政务专区售前架构师CloudLite认证!...Part1 腾讯政务专区售前架构师CloudLite认证 面向人群:腾讯生态合作伙伴中有意向成为腾讯政务专区售前架构师角色的个人和群体 学习目标:学习并了解腾讯政务专区产品知识,具备腾讯政务专区解决方案架构能力...目前,作为首个上架的腾讯行业认证课程,“腾讯政务专区售前架构师CloudLite认证”会在近期组织专场在线考试;感兴趣的小伙伴可扫描下方二维码报名考试并进行相关问题的交流。...具体考试上线时间将做后续通知~欢迎大家持续关注未来更多腾讯行业认证;证书在手,市场我有! 扫码加入腾讯学习交流群 或添加小助手微信:Tcloudedu777 学习了解更多业内精彩资讯

    1K40

    腾讯消息队列(Ckafka)监控最佳指南

    作者:朱丹阳,腾讯监控开发工程师 腾讯消息队列 CKafka 简介 消息队列 CKafka(Cloud Kafka)是基于开源 Apache Kafka 消息队列引擎,提供高吞吐性能、高可扩展性的消息队列服务...异步通信:很多时候,用户不想也不需要立即处理消息消息队列提供了异步处理机制,允许用户把一个消息放入队列,但并不立即处理它。想向队列中放入多少消息就放多少,然后在需要的时候再去处理它们。...写 message:消息写到 page cache,由异步线程刷盘。 message:消息直接从 page cache 转入 socket 发送出去。...02 如何在腾讯监控中配置 Dashboard 和告警,高效发现问题 1....进入腾讯监控,选择 Dashboard,然后选择预设 Dashboard 下的消息队列 CKafka 预设面板。

    3.4K20
    领券