`
frank1998819
  • 浏览: 764569 次
  • 性别: Icon_minigender_1
  • 来自: 南京
文章分类
社区版块
存档分类

深度解析RabbitMQ集群(转)

 
阅读更多

摘要:OpenStack已经在很多大型企业里支撑起核心生产业务,这都源于OpenStack中的核心技术与架构,超大规模高可用OpenStack平 台核心技术深入解析系列文章,主要介绍了EasyStack在企业级OpenStack一线实践中的所见所感,将分为消息队列篇,计算篇,存储篇,网络篇 等等,每篇中的内容都以基础、高级划分,将OpenStack落地最后一公里实打实所遇到的问题分享给大家。

在上一篇中,我们已经详细介绍了RabbitMQ的发展历程与AMQP协议中的相关概念,接下来,我们开始进入高级篇的部分,深入介绍如何搭建RabbitMQ集群,以及在RabbitMQ集群中做插件管理、构建HA方案、如何实现通过RabbitMQ支撑高并发的大规模生产集群,本文中将深入解析RabbitMQ服务器与集群。

一、RabbitMQ 服务器



首先,RabbitMQ是基于Erlang语言编写,RabbitMQ 服务器启动后,erlang框架会启动底层的Erlang node,上层启动Erlang 应用和其它的辅助应用,此架构类似于JVM,在一个节点的应用出问题时,该节点仍继续运行,如上图所示。

如何查看RabbitMQ当前的运行状态?

在部署好的集群当中,您可以通过rabbitmqctl status可以查看到RabbitMQ的状态。



上图中,红框内为运行的应用。 Rabbit即为RabbitMQ 服务器。其余则为Erlang/OTP提供的application。

• os_mon: operating system monitor,操作系统监控

• xmerl: Functions for exporting XML data to an external format,导出XML数据到外部格式

• mnesia: a distributed DataBase Management System (DBMS), appropriate for telecommunications applications and other Erlang applications which require continuous operation and exhibit soft real-time properties. 一个分布式数据库管理系统,适合于电信应用和其他需要持续操作并展示实时信息的应用

• SASL (System Architecture Support Libraries)

• Kernel & stdlib: The Kernel application is the first application started. It is mandatory in the sense that the minimal system based on Erlang/OTP consists of Kernel and STDLIB. 是第一个启动的服务,其作为Erlang框架的核心。

注:以上Erlang/OTP的应用都可以通过 “erl –man ”查询它的帮助文档。

如何启动RabbitMQ服务?

RabbitMQ 服务器是通过erl启动,启动时需要进行一系列的应用参数配置:



如上图所示,配置的参数包括了节点名称,配置,日志,插件等等

RabbitMQ 服务启动后,会运行哪些进程?

epmd(Erlang Port Mapper Daemon):

• Erlang Port Mapper Daemon (epmd). 当启动分布式的Erlang node时,epmd将记录IP/Port信息。 当使用rabbitmqctl join_cluster将Erlang node连接成集群时,epmd负责节点名称和IP/Port的转换。

Beam.smp:

RabbitMQ创建的众多处理消息的线程。

如何设置防火墙?

由于RabbitMQ中上述的应用都在监听不同的端口,如果rabbitmq-server所在的节点需要进行防火墙设置,则需要打开如下端口:

Java代码
  1. epmd:4369  
  2. rabbit:5672(默认值,可通过RABBITMQ_NODE_PORT更改)  
  3. rabbit management plugin: 15672  
  4. Kernel application: 41055  (在 rabbit.conf 中配置)  


如何管理RabbitMQ?

RabbitMQ提供的唯一操作工具就是rabbitmqctl。除了常规的 queue/exchange/policy/user/permission等操作外,可以利用它的“eval”子命令,来扩展出很多功能。比如查询 net_ticktime / erlang cookie。



如何选择RabbitMQ的消息保存方式?

RabbitMQ对于queue中的message的保存方式有两种方式:disc和ram。如果采用disc,则需要对 exchange/queue/delivery mode都要设置成durable模式。Disc方式的好处是当RabbitMQ失效了,message仍然可以在重启之后恢复。而使用ram方 式,RabbitMQ处理message的效率要高很多,ram和disc两种方式的效率比大概是3:1。所以如果在有其它HA手段保障的情况下,选用 ram方式是可以提高消息队列的工作效率的。

如果使用ram方式,RabbitMQ能够承载的访问量则取决于可用的内存数了。RabbitMQ使用两个参数来限制使用系统的内存,避免系统被自己独占。

Java代码
  1. [{rabbit, [{vm_memory_high_watermark_paging_ratio, 0.75},          {vm_memory_high_watermark, 0.4}]}].  


vm_memory_high_watermark:表示RabbitMQ使用内存的上限为系统内存的40%。也可以通过absolute参数制 定具体可用的内存数。当RabbitMQ使用内存超过这个限制时,RabbitMQ 将对消息的发布者进行限流,直到内存占用回到正常值以内。

Vm_memory_high_watermark_paging_ratio:表示当RabbitMQ达到0.4*0.75=30%,系统将对queue中的内容启用paging机制,将message等内容换页到disk 中。

RabbitMQ的内存使用情况可以通过“rabbitmqctl status”或者管理插件中的Web UI查询。



各个内存条目的含义请参照:https://www.rabbitmq.com/memory-use.html

当消息发送的速率超过了RabbitMQ的处理能力时该怎么办?

RabbitMQ会自动减慢这个连接的速率,让client端以为网络带宽变小了,发送消息的速率会受限,从而达到流控的目的。 使用”rabbitmqctl list_connections”查看连接,如果状态为“flow”,则说明这个连接处于flow-control 状态。

RabbitMQ集群

RabbitMQ基于Erlang编写,天然支持clustering。集群是保证可靠性的一种方式,同时可以通过水平扩展以达到增加消息吞吐能力的目的。



上图中是三个节点的RabbitMQ集群,Exchange A的metadata信息在所有节点上是一致的,queue的完整信息则只在它创建的那个节点上。每个RabbitMQ节点通常以“rabbit@”表 示,所以hostname在运行RabbitMQ的节点中很重要。注意:如果更改了hostname,需要重置RabbitMQ内部的数据库,否则服务无 法工作。

如何构建集群?

单个rabbitmq-server启动之后,在确保Erlang cookie相同的情况下,可以通过

Java代码
  1. rabbitmqctl stop_app  
  2.   
  3. rabbitmqctl join_cluster rabbit@<hostname>  
  4.   
  5. rabbitmqctl start_app  


将几个RabbitMQ节点连接成集群。RabbitMQ集群由Erlang/OTP提供的通讯机制保证集群节点之间的通讯。从逻辑上 讲,RabbitMQ集群是单一的message broker,消息队列消费者连接集群中的任一个节点都可以。如果配合HAProxy,client只需要访问单一一个地址,由HAProxy负责 load balance,将访问请求分发给各个节点。

如果单纯做试验,也可以在一个虚拟机上启动三个RabbitMQ的实例,只要在启动时通过设置RABBITMQ_NODE_PORT让三个实例监听不同端口即可。

RabbitMQ维护着四种类型的metadata: queue/exchange/binding/vhost,在集群中这些信息被同步到每个节点,因此当用户访问任何一个节点时,通过 rabbitmqctl查询到的queue/user/exchange等信息都是相同的。

通常我们将这些信息保存到磁盘上,也就是查询RabbitMQ状态时的“disc”方式,以便集群重启时可以根据保存的metadata信息重建exchange等。

对于exchange来讲,它的所有信息就是一个exchange名字加上一个查询表。查询表中记录了所有的queue binding。当message被发送到exchange时,client连接的channel对routing key进行比对,根据binding进行正确的转发。

对于Queue来讲,虽然它的metadata在每个节点上都有,但只有在它被创建的那个RabbitMQ 节点上才具有完整的信息:比如state/contents等,这个node被称为此queue的owner node。其他节点只知道这个queue的metadata信息和一个指向queue的owner node的指针。

如果一个client访问RabbitMQ的节点上没有需要的queue的完整信息,RabbitMQ将根据这个指针将请求转发到owner node。



这张图上可以看到,Exchange的所有信息被复制到集群中的所有节点,“Queue 1”的metadata被复制到每个节点,但它的完整信息(content)只存在于一个节点上,也就是这个queue的owner node。

Mnesia是RabbitMQ中的数据库,它是内嵌在Erlang中的no-SQL数据库。Exchange/Queue/Binding等的 metadata信息都保存在mnesia的数据库文件中。关于RabbitMQ的集群信息也保存在这里。Rabbitmqctl的reset操作实际上 就是清空了mnesia数据库所在目录的内容。

RabbitMQ集群模式

除了上面讲到的RabbitMQ 内嵌的clustering方式进行分布式的消息处理,RabbitMQ还有federation/shovel两种分布式方式,这两种方式以 RabbitMQ plugin的形式存在。RabbitMQ对网络延迟很敏感,在单个数据中心中使用clustering方式。在WAN环境中,则使用 Federation或Shovel。

以Shovel为例,在rabbitmq.conf中定义rabbitmq_shovel的配置,主要是对两个独立RabbitMQ 节点中,定义源和目的节点中exchange/queue的replication关系。当一个请求发送到源RabbitMQ节点时,先响应请求,之后根 据replication关系,shovel会异步的将message传送到目的RabbitMQ节点进行处理。

这里对federation/shovel联邦模式跟clustering集群模式一个简单的对比。



作者:石奎,EasyStack高级架构师,曾任职WindRiver/EMC/华为等知名企业,十余年Linux操作系统定制开发及 Kernel驱动开发经验,2012年开始贡献OpenStack社区,曾参与设计并实施国内金融领域首个支撑核心生产系统高可靠、高可用 OpenStack云平台,具有丰富的超大规模OpenStack云平台的设计与实施经验,去年开始深入研究NFV领域技术及项目设计实施。

分享到:
评论

相关推荐

    RabbitMQ实战 高效部署分布式消息队列 带目录 高清版 PDF

    《RabbitMQ实战:高效部署分布式消息队列》是一本深度解析RabbitMQ技术的书籍,旨在帮助读者理解和掌握如何在实际项目中高效地运用这一强大的消息中间件。书中不仅涵盖了RabbitMQ的基础知识,还深入探讨了其在分布式...

    RabbitMQ实战 高效部署分布式消息队列 PDF下载

    《RabbitMQ实战:高效部署分布式消息队列》是一本深度解析RabbitMQ技术的书籍,专注于帮助读者理解和掌握如何在实际项目中高效地部署和使用这个强大的消息中间件。RabbitMQ作为开源的消息代理和队列服务器,广泛应用...

    RabbitMQ高效部署分布式消息队列实战篇

    《RabbitMQ高效部署分布式消息队列实战篇》是一份深度解析RabbitMQ技术的教程,结合实际应用案例,旨在帮助读者深入理解并熟练掌握如何在分布式环境中高效部署和运用消息队列。RabbitMQ作为业界广泛采用的消息中间件...

    RabbitMQ实战:高效部署分布式消息队列

    《RabbitMQ实战:高效部署分布式消息队列》是一本深度解析RabbitMQ技术的书籍,旨在帮助读者理解和掌握如何在实际环境中有效地部署和利用分布式消息队列。RabbitMQ作为一个开源的消息代理和队列服务器,是实现异步...

    RabbitMQ 原版书

    这包括了如何处理高并发场景下的消息处理,如何实现消息的持久化存储,以及如何设计高可用的RabbitMQ集群。通过对具体案例的分析,帮助读者掌握RabbitMQ在复杂环境下的应用技巧。 ### 五、标签解析:“MQ Socket” ...

    rabbitmq-zabbix.zip

    结合Zabbix的自动发现和自动配置功能,当RabbitMQ集群发生变化时,如添加或移除节点,Zabbix可以自动更新监控配置,保持与系统同步。 综上所述,"rabbitmq-zabbix.zip"工具包提供了完整的RabbitMQ-Zabbix监控解决...

    RabbitMQ实战 高效部署分布式消息队列.pdf

    《RabbitMQ实战:高效部署分布式消息队列》是一本深度探讨RabbitMQ技术的书籍,旨在帮助读者理解和掌握如何在实际项目中高效地部署和使用这个强大的分布式消息队列系统。RabbitMQ是一个开源的消息代理和队列服务器,...

    RabbitMQ实战 高效部署分布式消息队列

    《RabbitMQ实战:高效部署分布式消息队列》是一本深度解析RabbitMQ技术的书籍,旨在帮助读者理解和掌握如何在分布式系统中有效地利用消息队列。RabbitMQ作为一款广泛应用的消息中间件,其核心功能在于提供可靠的异步...

    RabbitMQ实战 高效部署分布式消息队列(高清带标签)

    《RabbitMQ实战:高效部署分布式消息队列》是一本深度解析RabbitMQ技术的书籍,专注于实战应用和高效率的分布式系统构建。RabbitMQ作为一款广泛应用的消息中间件,其核心功能在于实现异步处理、解耦系统以及提供可靠...

    消息中间件-RabbitMQ.zip

    **RabbitMQ 深度解析** RabbitMQ 是一个开源的消息代理和队列服务器,它基于 Advanced Message Queuing Protocol (AMQP) 标准,广泛应用于分布式系统中,用于处理异步任务、数据同步以及应用程序之间的通信。...

    rabbitmq.7z

    **RabbitMQ 深度解析** RabbitMQ 是一个高度可扩展且极其灵活的消息队列服务,它属于消息中间件的一种。这个开源项目基于 AMQP(Advanced Message Queuing Protocol)协议,允许应用程序之间进行异步通信,确保数据...

    springCloud

    CentOs7.3 搭建 RabbitMQ 3.6 Cluster 集群服务: https://segmentfault.com/a/1190000010702020 Spring Boot 中使用 RabbitMQ: https://segmentfault.com/a/1190000011577243 4)断路器模式源于Martin Fowler的...

    深度解析java游戏服务器开发.zip

    Java的Distributed Map(如Hazelcast)和消息队列(如RabbitMQ、Kafka)等技术可以帮助实现这一目标。 总结来说,Java在游戏服务器开发中扮演了重要角色,其强大的网络编程能力、并发处理支持、丰富的库和框架,...

    追踪微服务的每一步:Spring Cloud分布式追踪的深度解析

    Spring Cloud 是建立在 Spring Boot 基础上...7. **Stream**:消息驱动的微服务,对 Kafka、RabbitMQ 等消息系统进行封装 。 8. **Sleuth**:分布式追踪系统,与 Zipkin 集成提供服务跟踪解决方案 。 9. **Alibaba Clo

    rabbitMQ-YuDao:芋道源码-rabbitMQ

    《芋道源码-rabbitMQ》是关于RabbitMQ深度解析的资源,尤其对Java开发者来说,这是一个深入理解RabbitMQ及其在Java应用中的实践的重要参考资料。RabbitMQ是一个广泛使用的开源消息代理和队列服务器,它基于AMQP...

    dotnet-NewLifeMQ是一个轻量级消息队列无延迟分发支持消费组和消息去重不支持集群部署

    《NewLifeMQ:轻量级消息队列的深度解析》 NewLifeMQ,作为一个专为.NET开发设计的消息队列系统,其核心特性在于其轻量级的架构、无延迟分发、消费组支持以及消息去重功能。这些特性使得它在分布式系统中,尤其是在...

    FlinkTutorial.rar

    《Apache Flink 深度解析教程》 Apache Flink 是一个开源的流处理和批处理框架,专注于实时数据处理,具有低延迟、高吞吐量以及强大的状态管理能力。本教程将围绕 Flink 的核心概念、架构、API 使用、数据源与数据...

    2024年java面试题-消息中间件RabbiMQ面试题

    ### 2024年Java面试题:消息中间件RabbitMQ面试题解析 #### 一、消息队列(MQ)的基本概念与作用 **1.1 什么是MQ(消息队列)** 消息队列(Message Queue, MQ)是一种应用程序间进行通信的数据通道,其主要功能是...

    flink-1.11.0-bin-scala_2.11.tgz

    《Apache Flink 1.11.0:流处理与批处理框架的深度解析》 Apache Flink 是一个开源的分布式流处理框架,其在大数据处理领域占据着重要的地位。Flink 的核心特性包括对实时数据流的低延迟处理、支持事件时间和窗口...

    大型电商项目 宜立方商城 项目源码

    《大型电商项目宜立方商城:深度解析分布式系统架构与源码分析》 在现代互联网行业中,电商项目扮演着至关重要的角色。"宜立方商城"作为一个大型电商项目,其背后的技术架构和源码设计无疑是我们深入学习和研究的...

Global site tag (gtag.js) - Google Analytics