诚聘php网站开发师谷歌广告投放

pingmian/2026/1/21 18:20:16/文章来源:
诚聘php网站开发师,谷歌广告投放,铁岭免费移动网站建设,google doc wordpress前言 在架构篇中我们介绍了现代IM消息系统的架构#xff0c;介绍了Timeline的抽象模型以及基于Timeline模型构建的一个支持『消息漫游』、『多端同步』和『消息检索』多种高级功能的消息系统的典型架构。架构篇中为了简化读者对Tablestore Timeline模型的理解#xff0c;概要…前言 在架构篇中我们介绍了现代IM消息系统的架构介绍了Timeline的抽象模型以及基于Timeline模型构建的一个支持『消息漫游』、『多端同步』和『消息检索』多种高级功能的消息系统的典型架构。架构篇中为了简化读者对Tablestore Timeline模型的理解概要性的对Timeline的基本逻辑模型做了介绍以及对消息系统中消息的多种同步模式、存储和索引的基本概念做了一个科普。 本篇文章是对架构篇的一个补充会对Tablestore的Timeline模型做一个非常详尽的解读让读者能够深入到实现层面了解Timeline的基本功能以及核心组件。最后我们还是会基于IM消息系统这个场景来看如何基于Tablestore Timeline实现IM场景下消息同步、存储和索引等基本功能。 Timeline模型 Timeline模型以『简单』为设计目标核心模块构成比较清晰明了主要包括 StoreTimeline存储库类似数据库的表的概念。Identifier用于区分Timeline的唯一标识。Meta用于描述Timeline的元数据元数据描述采用free-schema结构可自由包含任意列。Queue一个Timeline内所有Message存储在Queue内。MessageTimeline内传递的消息体也是一个free-schema的结构可自由包含任意列。Index包含Meta Index和Message Index可对Meta或Message内的任意列自定义索引提供灵活的多条件组合查询和搜索。 Timeline Store Timeline Store是Timeline的存储库对应于数据库内表的概念。上图是Timeline Store的结构图Store内会存储所有的Timeline数据。Timeline是一个面向海量消息的数据模型同时用于消息存储库和同步库需要满足多种要求 支撑海量数据存储对于消息存储库来说如果需要消息永久存储则随着时间的积累数据规模会越来越大需要存储库能应对长时间积累的海量消息数据存储需要能达到PB级容量。低存储成本消息数据的冷热区分是很明显的大部分查询都会集中在热数据所以对于冷数据需要有一个比较低成本的存储方式否则随着时间的积累数据量不断膨胀存储成本会非常大。数据生命周期管理不管是对于消息数据的存储还是同步数据都需要定义生命周期。存储库是用于在线存储消息数据本身通常需要设定一个较长周期的保存时间。而同步库是用于写扩散模式的在线或离线推送通常设定一个较短的保存时间。极高的写入吞吐各类场景下的消息系统除了类似微博、头条这种类型的Feeds流系统像绝大部分即时通讯或朋友圈这类消息场景通常是采用写扩散的消息同步模式写扩散要求底层存储具备极高的写入吞吐能力以应对消息洪峰。低延迟的读消息系统通常是应用在在线场景所以对于查询要求低延迟。 Tablestore Timeline的底层是基于LSM存储引擎的分布式数据库LSM的最大优势就是对写入非常友好天然适合消息写扩散的模式。同时对查询也做了极大优化例如热数据进缓存、bloom filter等等。数据表采用Range Partition的分区模式能提供水平扩展的服务能力以及能自动探测并处理热点分区的负载均衡策略。为了满足同步库和存储库对存储的不同要求也提供了一些灵活的自定义配置主要包括 Time to live数据生命周期可自定义数据生命周期例如永久保存或者保存N天。Storage type存储类型自定义存储类型对存储库来说HDD是最好的选择对同步库来说SSD是最好的选择。 Timeline Module Timeline Store内能存储海量的Timeline单个Timeline的详细结构图如上可以看到Timeline主要包含了三大部分 Timeline Meta元数据部分用于描述Timeline包括Identifier用于唯一标识Timeline可包含多个字段。Meta用于描述Timeline的元数据可包含任意个数任意类型的字段。Meta Index元数据索引可对元数据内任意属性列建索引支持多字段条件组合查询和检索。 Timeline Queue用于存储和同步消息的队列队列中元素由两部分组成Sequence Id顺序ID队列中用于定位Message的位点信息在队列中顺序ID保持递增。Message队列中承载消息的实体包含了消息的完整内容。 Timeline DataTimeline的数据部分就是MessageMessage主要包含Message消息实体其内部也可以包含任意数量任意类型字段。Message Index消息数据索引可对消息实体内任意列做索引支持多字段条件组合查询和检索。 IM消息系统建模 以一个简易版IM系统为例来看如何基于Tablestore Timeline模型建模。按照上图中的例子存在A、B、C三个用户A与B发生单聊A与C发生单聊以及A、B、C组成一个群聊来看下在这个场景下消息同步、存储以及读写流程分别如何基于Tablestore Timeline建模。 消息同步模型 消息同步选择写扩散模型能完全利用Tablestore Timeline的优势以及针对IM消息场景读多写少的特性通过写扩散来平衡读写均衡整个系统的资源。写扩散模型下每个接收消息的个体均拥有一个收件箱所有需要同步至该个体的消息需要投递到其收件箱内。图上例子中A、B、C三个用户分别拥有收件箱每个用户不同的设备端均从同一个收件箱内拉取新消息。 消息同步库 收件箱存储在同步库内同步库中每个收件箱对应一个Timeline。根据图上的例子总共存在3个Timeline作为收件箱。每个消息接收端保存有本地最新拉取的消息的SequenceID每次拉取新消息均是从该SequenceID开始拉取消息。对同步库的查询会比较频繁通常是对最新消息的查询所以要求热数据尽量缓存在内存中能提供高并发低延迟的查询。所以对同步库的配置一般是需要SSD存储。消息如果已经同步到了所有的终端则代表收件箱内的该消息已经被消费完毕理论上可以清理。但设计上来说不做主动清理而是给数据定义一个较短的生命周期来自动过期一般定义为一周或者两周。数据过期之后如果仍要同步拉取新消息则需要退化到读扩散的模式从存储库中拉取消息。 消息存储库 消息存储库中保存有每个会话的消息每个会话的发件箱对应一个Timeline。发件箱内的消息支持按会话维度拉取消息例如浏览某个会话内的历史消息则通过读取发件箱完成。一般来说新消息通过在线推送或者查询同步库可投递到各个接收端所以对存储库的查询会相对来说较少。而存储库用于长期存储消息例如永久存储相对同步库来说数据量会较大。所以存储库的选择一般是HDD数据生命周期根据消息需要保存的时间来定通常是一个较长的时间。 消息索引库 消息索引库依附于存储库使用了Timeline的Message Index可以对存储库内的消息进行索引例如对文本内容的全文索引、收件人、发件人以及发送时间的索引等能支持全文检索等高级查询和搜索。 总结 本篇文章主要对Tablestore Timeline模型进行了详解介绍了Timeline各模块包括Store、Meta、Queue、Data和Index等最后以一个简单的IM场景举例如何基于Timeline来建模。在下一篇实现篇中会直接基于Tablestore Timeline来实现一个简易版的支持单聊、群聊、元数据管理以及消息检索的IM系统敬请期待。 原文链接 本文为云栖社区原创内容未经允许不得转载。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/pingmian/87093.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

陕西煤化建设集团铜川分公司网站网站导航仿站

软件说明 使用Media Encoder,您将能够处理和管理多媒体。插入、转码、创建代理版本,并几乎以任何可用的格式输出。在应用程序中以单一方式使用多媒体,包括Premiere Pro、After Effects和Audition。 紧密整合 与Adobe Premiere Pro、After …

做欧美网站餐饮品牌设计方案

实战研究一下 EasyExcel 如何从指定文件位置进行读取数据 EasyExcel的使用背景EasyExcel的时候痛点EasyExcel对比其他框架 EasyExcel的编程模式EasyExcel读取的指定位置导入数据的流程表头校验invokeHeadMap()方法 数据处理invoke()方法 执行中断hasNextdoAfterAllAnalysed()方…

西宁公司做网站wordpress修改样式

Learn about the optimization loop 了解优化循环 Optimizing Model Parameters 优化模型参数 现在我们有了模型和数据,是时候通过优化数据上的参数来训练、验证和测试我们的模型了。训练模型是一个迭代过程;在每次迭代中,模型都会对输出进…

成都全美网站建设网站制作难吗

F. Paper Grading 大佬题解 一般关于前缀的问题基本都是Trie树。 首先将所给字符串建立一棵Trie树,Trie能够解决一个字符串在一个字符串集合中出现的次数,而查询前缀次数只需要找到Trie树中所给字符末尾的位置,那么其子树中打标记的次数即前…

二级域名网站wordpress做社交网站吗

平面方程(Plane Equation) 原文链接:http://www.songho.ca/math/plane/plane.html翻译:罗朝辉 (http://www.cnblogs.com/kesalin/)本文遵循“署名-非商业用途-保持一致”创作公用协议平面方程平面上的一点以及垂直于该平面的法线唯一定义了 3D 空间的一个…

建设银行 杭州招聘网站品牌网站建设大概费用

数据入湖Hudi Apache Hudi(简称:Hudi)使得您能在hadoop兼容的存储之上存储大量数据,同时它还提供两种原语,使得除了经典的批处理之外,还可以在数据湖上进行流处理。这两种原语分别是: Update/Delete记录:H…

专门做淘宝代运营的网站xml wordpress

来自 | 逐梦erhttps://zhumenger.blog.csdn.net/article/details/106530281本文仅作技术交流,如有侵权,请联系后台删除。数据可视化非常重要,因为错误或不充分的数据表示方法可能会毁掉原本很出色的数据分析工作。matplotlib 库是专门用于开发…

黑龙江省生产建设兵团知青网站wordpress 邮件激活

echo offecho 当前盘符:%~d0echo 当前盘符和路径:%~dp0echo 当前批处理全路径:%~f0echo 当前盘符和路径的短文件名格式:%~sdp0echo 当前CMD默认目录:%cd%echo 目录中有空格也可以加入""避免找不到路径echo 当…

绘本馆网站建设wordpress 扫描工具

一、系统方案 本设计采用STC89C5单片机作为主控制器,从机采用DHT11传感器采集温湿度、按键设置报警阀值,液晶1602显示,蜂鸣器报警,无线NRF2401模块。 二、硬件设计 原理图如下: 三、单片机软件设计 1、首先是系统…

校园网站开发需求文字seo 新旧网站 两个域名

阿里妹导读:一年多前,Java 界最近发生了一件大事,阿里开源 Spring Cloud Alibaba,并推出首个预览版。Spring Cloud 本身是一套微服务规范,并不是一个拿来即可用的框架,而 Spring Cloud Alibaba 的开源为开发…

微网站php源码公司网站的实例

这个话题我曾经写过文章,也在一些场合做过专题分享。今天换一种方式,你可以直接点击下面这个小程序,用十分钟左右的时间,听我再讲一讲吧。你需要在微信里面才能看到下面的小程序链接,并且可以直接点击你可以打开该文档…

织梦高清电影网站模板系统搭建流程

电脑犹如汽车,在使用过程中需要正确的方法,否则就会有win10系统potplayer经常弹出自动更新提示的情况出现,要处理win10系统potplayer经常弹出自动更新提示的问题,对于电脑专业人士来说并非难事;新手小白翻遍了整个网络…

杭州网站设计公司有哪些做公司 网站建设

vue页面使用html2canvas截图 vue使用vue-esign画布签名

建设厅网站沙场限期通知书建设部网站统计

Redis哨兵机制可以保证Redis服务的高可用性。它通过启动一个或多个哨兵进程,监控Redis主服务器是否宕机,如果宕机,哨兵进程会自动将一个从服务器(Slave)升级为主服务器(Master),并通…

奉新网站制作wordpress home index

摘要: 搭配ECS云服务器使用, ESSD可提供单盘高达100万IOPS的随机读写能力和低至0.1毫秒的单路时延,相比SSD云盘分别提升了50倍性能上限和降低80%读写时延,单台云服务器整体存储性能提升500%. 点此查看原文:http://cli…

虚拟货币网站建设沈阳工程信息招标网

我们很高兴地告诉大家,ONLYOFFICE 桌面编辑器现已上架麒麟软件商店。请阅读下文了解详情。 关于麒麟 麒麟是一款国产操作系统,主要是为了满足中国市场的需求和偏好而设计的。 它能够与各种硬件平台和软件应用程序的广泛兼容,因而受到认可。…

网站被做跳转怎么办购买域名之后怎么做网站

java运行中修改代码不能改变立刻应用到本次运行中转载于:https://www.cnblogs.com/Pusteblume/p/10211110.html

单职业传奇网站做图表的网站知乎

自从今年3月末AMD锐龙4000系列处理器正式登陆移动平台以来,目前已有多款机型上市,并涌现出了不少高热度、高性价比的机型。我们也体验测试了其中数款机型,总体上给用户的印象是是价格香、性能强。而今天牛叔要聊的这款机型,也是搭…

html5移动网站开发实例wordpress多个标签

JAVA入门级教学之(多态) 怎么理解多态:你本身就该喊你爹叫爹,你让你爹叫你爹就是强制认做爹 多态的使用: A a new D(); D类继承A类,父类型引用指向子类型对象 * 关于java语言汇总的多态语法机制&#x…

毕业设计 旅游网站建设二 网站建设的重要性

你是否曾读过一本让你欲罢不能的计算机书籍?它可能为你打开了新的技术世界大门,或者是帮助你解决了棘手的编程难题。 你可以从以下几个维度进行创作,也可以自由发挥。 此为内容创作模板,在发布之前请将不必要的内容删除 方向一…