范文健康探索娱乐情感热点
投稿投诉
热点动态
科技财经
情感日志
励志美文
娱乐时尚
游戏搞笑
探索旅游
历史星座
健康养生
美丽育儿
范文作文
教案论文

如何设计一个牛逼的消息队列?

  大家好,我是【架构摆渡人】,一只十年的程序猿。这是消息队列的第一篇文章,这个系列会给大家分享很多在实际工作中有用的经验,如果有收获,还请分享给更多的朋友。
  通过前面文章的学习,我们对消息队列的作用以及目前主流的一些消息队列中间件有了更深刻的了解。但是那些优秀的中间件都是别人写出来的,如果你在面试的时候,面试官问你: 如果让你去设计一个消息队列,你打算怎么做?  如果你对消息队列了解的不彻底,那么很有可能被这个问题问懵掉,最后支支吾吾的说不知道。 服务端
  我们从日常使用消息队列来入手,看设计一个消息队列到底要有哪些关键的点。当你要用消息队列的时候首先肯定是下载部署包,然后部署在服务器上。部署的这个程序我们就理解它是消息队列的服务端程序。在其他消息队列里面都有一个固定的名称: Broker 。 那么为什么需要Broker呢?
  你的消息要发送出去,必然得有接收方,这个接收方就是Broker。Broker收到消息后不是直接转给消费方,而是要先落盘,存储起来。这样才能保证消息不丢失,不影响业务。同时还有一些其他的业务操作,比如消息的查询。 存储
  既然说到存储,我们做业务的时候,都会用三方存储,也就是数据库,比如Mysql。但是MQ的存储,基本上都不会用三方存储,而是直接采用写磁盘的方式,也就是自己要设计要存储格式,自己写,自己解析等等一系列操作。
  当然,也不是说不能用三方存储去实现,下篇文章我们再给大家讲讲如何用数据库做消息队列的存储。用数据库做存储其实也就是利用已有的实现来解决复杂度,涉及到底层存储这块,而且还要考虑高性能,其实对技术要求很高的。
  像RocketMQ中的存储就涉及到CommitLog,ConsumeQueue,IndexFile等概念。最重要的是磁盘操作我们都知道很慢,而我们经常用的Mysql为了提高性能也是有一套很复杂的设计,比如redo log,buffer pool等,所以如果直接用数据库做存储,是不是相当于站在巨人的肩上去摘果实呢!
  主从
  我们设计了一个Broker,使用过程中万一这个Broker挂掉了怎么办?这里是不是得考虑下高可用性,所以Broker还需要有主从的设计。
  主节点的数据会同步给从节点,主节点出问题后,从节点可以顶上来提供服务,同时从节点也可以提供读的操作,为主节点减轻压力。
  分片
  一个Broker是部署在某一台服务器上面,这个服务的磁盘存储空间是有限制的,不可能无限扩容。所以当消息量很大的时候,如果只是一直往机器的本地磁盘写数据,最终会写不进去的。
  在设计的时候还要考虑数据分片的场景,一个Topic的数据可以分成很多份进行存储,分别存储在不同的Broker上,这样当磁盘不够的时候,可以通过增加Broker的节点来扩容。
  那么问题来了,客户端写入的时候怎么知道这个Topic有哪些分片的存储信息,怎么知道有哪些Broker是在线的呢?这就要引入另一个设计:注册中心,在RocketMq中叫NameServer。 注册中心
  NameServer叫注册中心或者路由中心都可以,本质上都一样。Broker启动的时候需要将自身的信息告诉NameServer,同时也要保持一个心跳检查,这样NameServer才能知道Broker当前是否处于正常状态。
  NameServer也要支持水平扩展,这样才能保证高可用性。既然要支持水平扩展,那么必然得无状态才行,但是NameServer本身就会存储一些数据,比如Broker信息。
  这里有几个实现方式:
  Broker启动的时候轮流向所有的NameServer进行注册,这样每个NameServer中都有全量的信息,即使某个节点挂了也不影响。RocketMQ就是使用的这种方式。
  Broker启动的时候只向某一台NameServer进行注册,立马返回,然后NameServer之间再进行相互同步,Eureka就是使用的这种方式。
  Broker启动的时候只向某一台NameServer进行注册,NameServer会同步向其他的NameServer进行数据的同步操作,等待所有写入成功或者半数写入成功,然后再返回给客户端。Zookeeper就是使用的这种方式。
  SDK
  服务端有了,还有一个必须要有的设计就是SDK了。应用程序通过依赖SDK就可以直接发送消息和消费消息。SDK同时可以考虑支持多语言,这样使用场景更广泛。
  SDK主要是用来跟Broker通信的,所以对于网络通信我们也要选择一个合适的框架,比如Netty就非常合适,你要是觉得太难,直接用Http协议也可以,或者直接支持多协议,这些都是需要考虑的场景。 后台管理
  后台管理可以实现很多治理的工作,方便我们在使用消息队列的时候去排查各种问题。
  核心功能点: 当前集群状态的查看 消息的查询 消息的消费轨迹查询 消息的重复投递 消息生产的监控大盘 消息消费的监控大盘 SDK消费线程数的动态调整 等等 总结
  本文只是简单的给大家介绍了下设计一个消息队列需要做哪些核心的工作,看起来就几个点而已。但是这几个点你要真正的去写代码实现难度是很大的。当然,我们其实也没必要自己去造轮子,因为你造了也不一定能比目前主流在用的好,但是整体的架构我们还是要了解的,至于细节就看自己需不需要深入了解了。比如消息存储那块,存储格式是怎样的?顺序写如何实现的?mmap技术如何应用的等等。
  原创:架构摆渡人(公众号ID:jiagoubaiduren),欢迎分享,转载请保留出处。
  本文已收录至学习网站 http://cxytiandi.com/ ,里面有Spring Boot, Spring Cloud,分库分表,微服务,面试等相关内容。

李瑾南营销团队改变打法,奕炫MAX能否一炮打响?引言持续预热一段时期之后,东风风神今年最重磅的轿车新品奕炫MAX,日前迎来下线和预售,新车将推出三款车型,预售价区间为9。7911。59万元。月初,时值我D百年大庆,华夏大地一片欢刘作虎的小目标,拿下国内手机线上高端第一宝座一切都是利益惹的祸嘛这还得从刘作虎去年的小目标说起,今年一加是想要争夺国内线上高端第一的,从今年一加9系列发布的动作就能看出来,又是联手哈苏,又是签约胡歌周迅作为代言人,着实是吸了爱心传递书送温暖捐图书送温暖活动圆满结束中国公益在线郑州讯(公益记者张文孟)为满足农村留守困境儿童的阅读需求,让广大农村留守困境儿童感受到社会的关爱,感受到阅读的美好,郑州市金水区恩夕社会工作服务中心联合枫叶小熊幼儿园自小水滴爱心图书共享阅读暨文明宣讲志愿服务走进六十四中中国公益在线郑州讯(公益记者张文孟)12月23日上午大课间,郑州市第六十四中学联合郑州市小水滴志愿互助中心举办爱心图书共享阅读活动,全校六百多名师生参加了本次活动。郑州市第六十四中饿了么是人跑的吗?比美团还垃圾今天下午跑了4单饿了么,第一单是奖励3元,总单价6元,这单送到就9元了,但是送时间好像是25分钟分钟,第二单好像是30分钟,直接导致第三单根本没时间去取货,然后第三单超时10分钟多中牟县开展垃圾分类小课堂活动2月3日下午由中牟县妇联中牟县雁鸣湖镇政府雁鸣湖镇新时代文明实践所志愿服务站联合共同开展温暖回乡路共铸留守情之你是我手心里的宝冬令营活动,一起陪留守儿童和困境孩子们度过了一个快乐又富德生命人寿线上健康讲座与健身教程分享活动即将上线富德生命人寿第十五届客户节线上健康讲座与健身教程分享活动即将上线心手相连,生命有爱,富德生命第十五届客户节正在如火如荼地进行中,活动内容精彩纷呈,围绕绿色环保建党100周年东京奥运618!千元机有什么好手机推荐的随着目前手机的发展速度越来越快,可不要小看了现在的千元机,目前的千元机不仅有价格方面的优势,在功能这块做的也的确很好。更何况,对于父母而言,这个价位的手机再适合不过了。首先,父母对坦克品牌总有出圈的理由有一种风头,叫第二十四届保定车展。被戏谑的主角正是本届成都车展上参展的长城汽车,叫嚣的势头也从坦克品牌拉开了序幕。坦克的想象力它们来了,这是一场家族式的集合。随着坦克300上市之后音乐自学者的福利宋大叔教音乐如果你突然对音乐来了兴致,想要自学一下,那么你有一个非常好的选择宋大叔教音乐。宋大叔本名宋及正,系台湾某大学的音乐系教授,曾留学美国,对西方及中国音乐都研究颇深。宋大叔教音乐共五个凡尔赛C5X登录成都车展,喜欢巴适就去看看成都国际车展将于8月29日正式拉开帷幕。据官方消息透露,届时,东风雪铁龙将携手凡尔赛C5X再次释放凡尔赛大招。作为雪铁龙倾力打造的引领潮流,重塑B级新标杆的新势座驾,在本次成都车展
人为气候变化导致2020年飓风降雨科技日报北京4月12日电(记者张梦然)英国自然通讯杂志12日发表的一篇论文认为,与工业化前水平相比,人类引发的气候变化致2020年大西洋飓风季的小时降雨量增加多达10。2020年飓当断则断,评芒格减仓阿里4月11日,从美国市场传来消息,98岁的查理芒格先生旗下的DailyJournal公司对外界正式披露了其2022年第一季度持仓明细,其中最令外界关注的是相对2021年底,这家报纸和2020冲击高端的国产手机对比今年的国产手机到现在虽然已经发布了很多,但是真正在冲击高端的也就这么三款吧,第一就是OPPO的findx5pro,还有就是刚刚发布的Vivoxnote,最后一个就是荣耀magic4竟不到千元!小米新款全面屏电视要被疯抢小米43英寸全高清电视EA432022款近日于京东商城限时促销中,到手价仅为999元,不到千元的价格就能享受到全高清智能影音,立体声扬声器,还有小米AI生态控制,卧室的第一台观影神网传骑手送餐加价?回应商家只给米饭配送费却要求送40斤大米4月12日,一段视频迅速在网上传播。视频中,一名外卖骑手在电话中告诉对方你是(送)大米的,不加价我不帮你送疑似向客户要求送餐加价。该视频被上传至抖音平台后,迅速引发广泛关注。事件真观测显示银河系中,它俩相遇会制造出大量恒星参考消息网4月13日报道据美国科学新闻双周刊网站4月1日报道,就像两位伟大的词曲作者并肩工作,相互激励,创作出他们最好的作品一样,大小麦哲伦星云每次相遇时都会产生新的恒星。肉眼可见女朋友最近看上了一款OPPOReno7手机,吵着要我给她买女朋友最近看上了一款OPPOReno7手机,吵着闹着要我给她买,可是明明前不久才换的新手机,OPPO简直就是女孩子的收割机啊。不过话说回来,这款手机是真漂亮,不得不说OPPO手机系人民快评理性看待快递小哥日入万元来源人民网顺丰同城骑士日入过万?据报道,顺丰同城回应称,该顺丰同城骑士共完成60笔同城配送订单,系企业用户下单,订单佣金计提总额达10067。75元。其中基础佣金534元,各类特殊如果这题都不会面试官还会继续问我JVM如何判断对象是否可回收不懂就问,世界都快毁灭了我为啥还要在这背八股写论文(滑稽)首先,对于JVM来说,什么是垃圾?简单说就是内存中已经不再被使用到的空间就是垃圾其次,什么是垃圾收集(GarbageCol做活党建赋能数字经济大文章来源中工网近年来,大数据云计算人工智能区块链等技术加速创新,日益融入经济社会发展各领域全过程,数字经济发展速度之快辐射范围之广影响程度之深前所未有,正在成为重组全球要素资源重塑全球特斯拉在华部分进口及国产Model3电动汽车北京商报讯(记者刘洋刘晓梦)4月7日,国家市场监督管理总局发布消息称,特斯拉汽车(北京)有限公司特斯拉(上海)有限公司根据缺陷汽车产品召回管理条例和缺陷汽车产品召回管理条例实施办法