Java充电社
专辑
博文
联系我
本人继续续收门徒,亲手指导
RabbitMQ第14篇:RabbitMQ集群
相关专辑:
RabbitMQ专题
<div style="display:none"></div> 相关视频地址:<a target="_blank" href="https://www.bilibili.com/video/BV1cb4y1o7zz?p=83">https://www.bilibili.com/video/BV1cb4y1o7zz?p=83</a> ## 14.1、clustering ### 1)使用集群的原因 最开始我们介绍了如何安装及运行 RabbitMQ 服务,不过这些是单机版的,无法满足目前真实应用的要求。如果 RabbitMQ 服务器遇到内存崩溃、机器掉电或者主板故障等情况,该怎么办?单台 RabbitMQ服务器可以满足每秒 1000 条消息的吞吐量,那么如果应用需要 RabbitMQ 服务满足每秒 10 万条消息的吞吐量呢?购买昂贵的服务器来增强单机 RabbitMQ 务的性能显得捉襟见肘,搭建一个RabbitMQ 集群才是解决实际问题的关键。 ### 2)搭建步骤 1. 修改 3 台机器的主机名称 ```shell vim /etc/hostname ``` 2. 配置各个节点的 hosts 文件,让各个节点都能互相识别对方 ```shell vim /etc/hosts 10.211.55.74 node1 10.211.55.75 node2 10.211.55.76 node3 ``` 3. 以确保各个节点的 cookie 文件使用的是同一个值,在 node1 上执行远程操作命令 ```shell scp /var/lib/rabbitmq/.erlang.cookie root@node2:/var/lib/rabbitmq/.erlang.cookie scp /var/lib/rabbitmq/.erlang.cookie root@node3:/var/lib/rabbitmq/.erlang.cookie ``` 4. 启动 RabbitMQ 服务,顺带启动 Erlang 虚拟机和 RbbitMQ 应用服务(在三台节点上分别执行以下命令) ```shell rabbitmq-server -detached ``` 5. 在节点 2 执行 ```shell # rabbitmqctl stop 会将 Erlang 虚拟机关闭, rabbitmqctl stop_app 只关闭 RabbitMQ 服务 rabbitmqctl stop_app rabbitmqctl reset rabbitmqctl join_cluster rabbit@node1 # 只启动应用服务 rabbitmqctl start_app ``` 6. 在节点 3 执行 ```html rabbitmqctl stop_app rabbitmqctl reset rabbitmqctl join_cluster rabbit@node2 rabbitmqctl start_app ``` 7. 集群状态 ```shell rabbitmqctl cluster_status ``` 8. 需要重新设置用户 ```shell # 创建账号 rabbitmqctl add_user admin 123 # 设置用户角色 rabbitmqctl set_user_tags admin administrator # 设置用户权限 rabbitmqctl set_permissions -p "/" admin "." "." ".*" ``` 9. 解除集群节点(node2 和 node3 机器分别执行) ```shell rabbitmqctl stop_app rabbitmqctl reset rabbitmqctl start_app rabbitmqctl cluster_status # node1 机器上执行 rabbitmqctl forget_cluster_node rabbit@node2 ``` ## 14.2、镜像队列 ### 1)使用镜像的原因 如果 RabbitMQ 集群中只有一个 Broker 节点,那么该节点的失效将导致整体服务的临时性不可用,并且也可能会导致消息的丢失。可以将所有消息都设置为持久化,并且对应队列的durable属性也设置为true,但是这样仍然无法避免由于缓存导致的问题:因为消息在发送之后和被写入磁盘井执行刷盘动作之间存在一个短暂却会产生问题的时间窗。通过 publisherconfirm 机制能够确保客户端知道哪些消息己经存入磁盘,尽管如此, 一般不希望遇到因单点故障导致的服务不可用。 引入镜像队列(Mirror Queue)的机制,可以将队列镜像到集群中的其他 Broker 节点之上,如果集群中的一个节点失效了,队列能自动地切换到镜像中的另一个节点上以保证服务的可用性。 ### 2)搭建步骤 1. 启动三台集群节点 2. 随便找一个节点添加 policy ![](https://itsoku.oss-cn-hangzhou.aliyuncs.com/itsoku/blog/article/392/fc42e5a3-eec7-496d-8e04-798783711be4.png) 3. 在 node1 上创建一个队列发送一条消息,队列存在镜像队列 ![](https://itsoku.oss-cn-hangzhou.aliyuncs.com/itsoku/blog/article/392/70ab3d93-35aa-400c-a593-ad9456891b2c.png) 4. 停掉 node1 之后发现 node2 成为镜像队列 ![](https://itsoku.oss-cn-hangzhou.aliyuncs.com/itsoku/blog/article/392/cc01c395-56b0-4bde-85eb-8df975651463.png) 5. 就算整个集群只剩下一台机器了,依然能消费队列里面的消息,说明队列里面的消息被镜像队列传递到相应机器里面了 <a style="display:none" target="_blank" href="https://mp.weixin.qq.com/s/_S1DD2JADnXvpexxaBwLLg" style="color:red; font-size:20px; font-weight:bold">继续收门徒,亲手带,月薪 4W 以下的可以来找我</a> ## 最新资料 1. <a href="https://mp.weixin.qq.com/s?__biz=MzkzOTI3Nzc0Mg==&mid=2247484964&idx=2&sn=c81bce2f26015ee0f9632ddc6c67df03&scene=21#wechat_redirect" target="_blank">尚硅谷 Java 学科全套教程(总 207.77GB)</a> 2. <a href="https://mp.weixin.qq.com/s?__biz=MzkwOTAyMTY2NA==&mid=2247484192&idx=1&sn=505f2faaa4cc911f553850667749bcbb&scene=21#wechat_redirect" target="_blank">2021 最新版 Java 微服务学习线路图 + 视频</a> 3. <a href="https://mp.weixin.qq.com/s?__biz=MzkwOTAyMTY2NA==&mid=2247484573&idx=1&sn=7f3d83892186c16c57bc0b99f03f1ffd&scene=21#wechat_redirect" target="_blank">阿里技术大佬整理的《Spring 学习笔记.pdf》</a> 4. <a href="https://mp.weixin.qq.com/s?__biz=MzkwOTAyMTY2NA==&mid=2247484544&idx=2&sn=c1dfe907cfaa5b9ae8e66fc247ccbe84&scene=21#wechat_redirect" target="_blank">阿里大佬的《MySQL 学习笔记高清.pdf》</a> 5. <a href="https://mp.weixin.qq.com/s?__biz=MzkwOTAyMTY2NA==&mid=2247485167&idx=1&sn=48d75c8e93e748235a3547f34921dfb7&scene=21#wechat_redirect" target="_blank">2021 版 java 高并发常见面试题汇总.pdf</a> 6. <a href="https://mp.weixin.qq.com/s?__biz=MzkwOTAyMTY2NA==&mid=2247485664&idx=1&sn=435f9f515a8f881642820d7790ad20ce&scene=21#wechat_redirect" target="_blank">Idea 快捷键大全.pdf</a> ![](https://itsoku.oss-cn-hangzhou.aliyuncs.com/itsoku/blog/article/1/2883e86e-3eff-404a-8943-0066e5e2b454.png)
相关专辑:
RabbitMQ专题