理论修炼之RabbitMQ,消息队列服务的稳健者

  • ????欢迎点赞 :???? 收藏 ⭐留言 ???? 如有错误敬请指正,赐人玫瑰,手留余香!

  • ????本文作者:由webmote 原创,首发于 【掘金】

  • ????作者格言:生活在于折腾,当你不折腾生活时,生活就开始折腾你,让我们一起加油!????????????

???? 序言

在ETCD节有讲过,对于架构师来说,对中间件的理论研究和熟悉不是过分的要求,以前大意了,主要偏向应用层了,今天就来学习RabbitMQ,这个消息队列服务的稳健者。

当然由于RabbitMQ内容比较丰富,因此这里先阐述下消息组件的几种模式,然后注重于连接管理。其他章节后续也许会进一步学习,有所得必和大家分享。

???? 01. RabbitMQ支持的几种队列模式


还是这个图精简,一下子就看完了6种模式。

???? 01.1 简单队列模式

1个生产者,1个消费者。这种模式下消费者是按照消息的生产顺序严格进行消费的,可以看作是严格顺序消息队列。

???? 01.2 工作队列

1个生产者,多个消费者,消费者按照次序逐次把消息排放到各个消费者。因此默认情况下,消费的调度并不是按照工作量来的,而是按照顺序公平调度来的。

幸运的是RabbitMQ提供了参数,可以修改使用带有prefetch_count=1设置的Channel#basic_qos方法 。这使用basic.qos协议方法告诉 RabbitMQ 一次不要给一个工人多个消息。或者,换句话说,在处理并确认前一条消息之前,不要向工作人员发送新消息。相反,它会将它分派给下一个不忙的工人。

channel.basic_qos(prefetch_count= 1 )

???? 01.3 发布、订阅模式

也是1个生产者,多个消费者,不过与上面方案不同的是每一个消费者都有自己的一个队列。

生产者将消息直发送到交换机,每个队列都要绑定到交换机。有几种可用的交换类型:direct、topic、headers 和fanout。我们将关注最后一个——它就是广播(fanout)

因此无论交换机绑定多少队列,交换机总会保证消息被广播给每一个队列。

???? 01.4 路由模式

仍然是多个消费者,生产者嘛,就不一定了。这里生产者把消息发送到 direct类型的交换机上。该交换机按照绑定的Key路由消息到固定的队列。

???? 01.5 主题模式

主题模式相比路由模式,其更灵活,按照订阅的主题建立相关队列,交换机按照主题路由消息到各个队列。

这里一条消息如果负责多个队列的规则,则消息被路由分发到多个队列。当然如果多个规则都匹配一条消息,在一个队列内这条消息也仅被路由1次。

主题可以支持通配符*和#。

???? 01.6 RPC模式

大家都知道RPC是远程过程调用,其可以返回调用后执行的结果值,因此通过RPC模式,可以利用RabbitMQ构建一个基于RPC通讯的分布式微服务系统。

???? 02 客户端连接

这里的连接介绍基于.net client sdk,当然java的客户端也是类似。但其他客户端sdk可能会不太一样,因此谨慎参考。

RabbitMQ 支持的所有协议都是基于 TCP 的,并维持长连接(每个协议操作不打开新连接)以提高效率。

当不再需要连接时,应用程序必须关闭它们以节省资源。否则可能出现连接泄露问题,有最终耗尽其目标资源节点的风险。

如果我们使用rabbitmq的监控面板,请注意:RabbitMQ 记录所有发送至少 1 字节数据的入站客户端连接。不会记录在没有任何活动的情况下打开的连接。

利用监控面板,可以轻松监控连接的泄露情况。

当然如果频繁打开关闭连接,对系统的性能也会造成影响,我们也可以监控是否频繁打开关闭连接。

发布消息的连接可能速度很快,但读和处理消息可能很慢,导致速度不匹配。这时,会自动触发背压式流,这时候读消息不受影响,但写受到流控控制,导致速度放慢。

.net client 和 java client的sdk均支持连接故障自动恢复,因此编程者几乎不用做太多工作。

虽然标准的sdk提供了连接池管理,但并非最优。而 spring 框架提供了丰富的连接池二次封装,其可以管理单链接多通道或多连接多通道模式的连接池,也提供了发布确认等相关封装。

作为.net 开发者,我们只有羡慕的份了,当然仿照其写个.net版的也应该可以,不过这个能力要求有点高,我试试写一个看看。

???? 03 强一致性方案

为了保证消息中间件的强一致性,RabbitMQ提供了集群镜像功能,交换机和队列持久化,以及发布和订阅消息的确认(ack)机制,因此我们如果需要强一致性,那么避免不了和这些技术打打交道。

通过发送消息、推送消息的确认ack方案,虚线表示,的确提升了消息投递、消费的准确性。

并且确认ack均支持异步批量方案,因此数据的读写吞吐量不用担心受到影响。

生产者在采用批量ack时,可以适当开启缓存,缓存待确认的消息,可以完美解决ack确认问题。

???? 04. 小结

RabbitMQ的内容非常多,这里仅仅介绍了一些很小的要点,后续有时间仍需要继续学习!

例行小结,理性看待!

结的是啥啊,结的是我想你点赞而不可得的寂寞。????????????

????都看到这了,还在乎点个赞吗?

????都点赞了,还在乎一个收藏吗?

????都收藏了,还在乎一个评论吗?

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

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

相关文章

为什么年龄大了近视还增加_年龄明明一样大,为什么有人长得年轻,有人显老呢?...

台湾不老男神林志颖,始终是十几年前演偶像剧的脸。而德云社郭德纲与他是同龄人却饱经沧桑显得更加老相。这是一件让人哭笑不得的事,也被很多人编成段子。那么为什么有些人看起来年轻有些人却老的很快呢?哪一种更长寿呢?接下来让我…

利用Asp.net中的AJAX制作网页上自动选取开始日期及结束日期的用户自定义控件...

前段时间用过一个酒店入住预约网站,当你点击"入住时间"时会悬浮出一对并列的日历,然后点击左边的日历就能选择入住时间,点击右侧的日历就能自动得到离店时间,当时没有太留意是怎么实现的,现在在做项目时&…

【00】架构型

为什么80%的码农都做不了架构师?>>> 1、架构型(archetype) 一种形式,所有的东西或多或少地遵守。一种形式,属于同一类型的类都或多或少地遵守,包括属性、链接、方法、插入点、交互。 2、领域无…

SQL进阶提升(疑惑篇order by)-学习sql server2005 step by step(十一)

这篇主要发出两个疑惑,希望有兴趣的人解答,谢谢! 1.newid()疑惑 1 create table tb (aa int,bb char(1)) 2 insert tb values(1,A) 3 insert tb values(1,B) 4 insert tb values(1,C) 5 insert tb values(1,D) 6 7 insert tb value…

钟南山团队在患者粪便中检出新冠活病毒,国家卫健委回应!专家:做好这事很重要...

全世界只有3.14 % 的人关注了青少年数学之旅2月13日下午,在广东省人民政府新闻办召开的疫情防控新闻发布会上,钟南山院士团队成员、广州医科大学国家呼吸疾病重点实验室副主任、教授赵金存介绍,该团队在P3实验室中,在中山大学附属…

CSDN《某一程序员竟然吃过shi?让我们走进他的生活,揭露背后的故事》

CSDN《某一程序员竟然吃过屎?我们走进他的生活,揭露背后的故事》 ——————————接下来让我们走进他的故事 到底是什么原因让他吃屎 这是这位程序员的自曝,我很好奇的不是他吃过屎,我在好奇是啥味的~ 接下来我们开始咨询这…

专升本c语言网课听谁的好_都说塑钢泥比玻璃胶好,填缝永不变黑,师傅却说不好用,听谁的?...

新房装修,我一点不想再用玻璃胶来填补缝隙了。像洗手台、淋浴房、厨房水槽这些地方,不管用多贵多好的玻璃胶,最后,它都会变黑发霉。朋友同我说,可以用塑钢泥替代,20年不发霉~他说,现在很多业主家…

技术分享|明源云天际集成开放平台接口中心基于IdentityServer4的鉴权机制

源宝导读:企业数字化生态建设中为解决集成多样性和资源统一管理的痛点引入企业级网关,网关作为资源访问的大门,身份认证鉴权是其业务的重中之重,本文将介绍企业级网关-天际集成开放平台是如何通过IdentityServer4来做到身份认证和…

设计模式--6大原则--单一职责原则

2019独角兽企业重金招聘Python工程师标准>>> 单一职责原则(Single Responsibility Principle),简称SRP。 定义: There should never be more than one reason for a class to change. 应该有且仅有一个原因引起类的变更…

法国为何是伟大数学家的摇篮?

全世界只有3.14 % 的人关注了青少年数学之旅笛卡尔、韦达、帕斯卡、费马、拉格朗日、拉普拉斯、达朗贝尔、勒让德、蒙日、彭赛列、柯西、傅里叶、庞加莱、伽罗华、格罗藤迪克…… 这些令无数大学生“闻风丧胆”的数学家,基本上都诞生于十七至二十世纪的法国。解析几…

(转)WCF教程系列(1)-创建第一个WCF程序

作为微软技术.net 3.5的三大核心技术之一的WCF虽然没有WPF美丽的外观但是它却是我们开发分布式程序的利器但是目前关于WCF方面的资料相当稀少希望我的这一系列文章可以帮助大家尽快入门下面先介绍一下我的开发环境吧操作系统:windows vista business版本编译器&…

03 Files

本章提要-----------------------------------------------组成 oracle 的 8 种主要文件(包括 instance 和 database)instance: parameter file, trace file, alert filedatabase: data file, temp file, control file, redo log file, password file简单概述:parameter file: …

TensorFlow发布全新版本,又会带来哪些变革?

全世界只有3.14 % 的人关注了青少年数学之旅经过几年的发展,深度学习方法摧枯拉朽般地超越了传统方法,成为人工智能领域最热门的技术。之后,谷歌、亚马逊、百度、Facebook 纷纷开源了自己的深度学习框架。而支撑AlphaGo的核心技术架构--Tenso…

码农身份得到正式认证

各位同行的兄弟姐妹们,我们的码农(新生代农民工)身份已经得到国家正式确认,程序员这个职业也正式并到农民工行列了。现在互联网大厂,大部分程序员都是在做着模式化开发工作,已经没有技术含量了,…

面试字节我被String类的问题给问死了!

“” 是怎么连接字符串的?(JDK1.7及以上) 总结: 使用 “” 连接字符串时,实际上是使用临时创建的StringBuilder对象来辅助完成的。 对于编译时常量,在编译后直接计算出字符串的值,而不会在运行…

加州大学惊现神操作!物理教授用数学论文摆脱400美元交通罚单,却惨被网友大反转.........

全世界只有3.14 % 的人关注了青少年数学之旅“学好数理化,走遍天下都不怕。”这句从上个世纪八十年代流传下来的金句,至今仍然哺育着理工科的莘莘学子。为了让模友们更好的理解这句话,今天就让小天给你们涨涨姿势,见识一下什么是学…

VMware虚拟机VMDK 快照 数据恢复成功

VMware虚拟机VMDK 快照 数据恢复成功【故障描述】某影院使用的票管理系统安装在一台虚拟中,数据库采用的是Oracle9I,虚拟机在安装好后做了一次快照,期间又做过一次快照,在正常使用过程,虚拟突然崩溃,无法启动&#xff…

[转]两个经典的windbg调试案例,值得学习。

1. 调试Bug的神兵利器:通过WinDbg条件断点收集Log 原文地址:http://blogs.msdn.com/yizhang/archive/2009/03/30/bug-windbg-log.aspx 调试Bug的神兵利器:通过WinDbg条件断点收集Log 前段时间花了几天一直在用WinDbg调试一个比较棘手的Bug。…

设计模式之观察者

观察者模式介绍观察者又名事件订阅者、监听者。观察者模式是一种行为设计模式,允许你定义一种订阅机制,可在对象事件发生时通知多个“观察者”该对象的其他对象。通知目标:拥有一些值得关注的状态的对象。发布者:它要自身的状态改…

二面京东被问到Java 反射,我直呼好家伙,这我不是必过吗?

二面京东被问到Java 反射,我直呼好家伙,这我不是必过吗?用多久我会升职加薪、当上技术总监、迎娶漂亮学姐、走上人生巅峰!想想还有点小激动。 好了开始分享面试经历 说说你反射的理解 到底什么是反射呢??…