RabbitMQ 集群部署方案

devtools/2025/3/1 11:12:46/
RabbitMQ
  • 一、安装 RabbitMQ

  • 二、更改配置文件

  • 三、配置集群

  • 四、测试

  • 环境准备:三台服务器,系统是 CentOS7

  • IP地址分别是:

一、安装 RabbitMQ

记得配置yum源,避免不必要的错误

在三台服务器上分别安装 erlang 和 rabbitmq-server

  1. 安装 RabbitMQ 运行环境

    yum install -y erlang
    
  2. 安装软件 RabbitMQ

    yum install -y rabbitmq-server
    

二、更改配置文件

一下配置在三台服务器上都要修改

  1. 更改 RabbitMQ 配置文件

    vim /etc/rabbitmq/rabbitmq.config
    

    找到 %%{loopback_users, []}, 改为下面内容,大概在 53 行

    {loopback_users, []}
    
  2. 更改 hosts 配置主机名解析

    192.168.152.71 rabbitmq1
    192.168.152.72 rabbitmq2
    192.168.152.73 rabbitmq3
    

    可以 ping 一下看是否配置成功

三、配置集群

  1. 改主机名,对照 hosts 配置的主机名解析,把对用服务器的主机名改为相应的解析
    如:192.168.152.71

    hostnamectl set-hostname rabbitmq1
    

    192.168.152.72

    hostnamectl set-hostname rabbitmq2
    

    192.168.152.73

    hostnamectl set-hostname rabbitmq3
    

    然后全部都 exit 重新登录

  2. 启动三台服务器的 RabbitMQ 服务

    systemctl start rabbitmq-server
    systemctl enable rabbitmq-server
    
  3. 统一三台服务器的 erlang.cookie,把 rabbitmq1 的 erlang.cookie 传输到其它两台

    scp /var/lib/rabbitmq/.erlang.cookie rabbitmq2:/var/lib/rabbitmq/.erlang.cookie
    scp /var/lib/rabbitmq/.erlang.cookie rabbitmq3:/var/lib/rabbitmq/.erlang.cookie
    
  4. 运行 cat /var/lib/rabbitmq/.erlang.cookie,查看三台服务器的值是否一致,一致后再重启 rabbitmq2 和 rabbitmq3 的 RabbitMQ 服务

    systemctl restart rabbitmq-server
    
  5. 查看 RabbitMQ 的节点状态

    rabbitmqctl cluster_status
    

    结果如下即为正确

    # rabbitmq1 的结果:
    Cluster status of node rabbit@rabbitmq1 ...
    [{nodes,[{disc,[rabbit@rabbitmq1]}]},{running_nodes,[rabbit@rabbitmq1]},{cluster_name,<<"rabbit@rabbitmq1">>},{partitions,[]}]
    ...done.# rabbitmq2 的结果:
    Cluster status of node rabbit@rabbitmq2 ...
    [{nodes,[{disc,[rabbit@rabbitmq2]}]},{running_nodes,[rabbit@rabbitmq2]},{cluster_name,<<"rabbit@rabbitmq2">>},{partitions,[]}]
    ...done.# rabbitmq3 的结果:
    Cluster status of node rabbit@rabbitmq3 ...
    [{nodes,[{disc,[rabbit@rabbitmq3]}]},{running_nodes,[rabbit@rabbitmq3]},{cluster_name,<<"rabbit@rabbitmq3">>},{partitions,[]}]
    ...done.
    
  6. 停止 rabbitmq2 和 rabbitmq3 主机的 RabbitMQ 应用

    rabbitmqctl stop_app
    
  7. rabbitmq2 和 rabbitmq3 加入 rabbitmq1 的集群

    rabbitmqctl join_cluster rabbit@rabbitmq1	
    
  8. 启动 rabbitmq2 和 rabbitmq3 主机的 RabbitMQ 应用,并再次查看 RabbitMQ 的节点状态

    rabbitmqctl start_app
    

    再三台服务器上执行 rabbitmqctl cluster_status 命令,结果就会变为下面这样

    # rabbitmq1 的结果:
    Cluster status of node rabbit@rabbitmq1 ...
    [{nodes,[{disc,[rabbit@rabbitmq1,rabbit@rabbitmq2,rabbit@rabbitmq3]}]},{running_nodes,[rabbit@rabbitmq2,rabbit@rabbitmq3,rabbit@rabbitmq1]},{cluster_name,<<"rabbit@rabbitmq1">>},{partitions,[]}]
    ...done.# rabbitmq2 的结果:
    Cluster status of node rabbit@rabbitmq2 ...
    [{nodes,[{disc,[rabbit@rabbitmq1,rabbit@rabbitmq2,rabbit@rabbitmq3]}]},{running_nodes,[rabbit@rabbitmq1,rabbit@rabbitmq3,rabbit@rabbitmq2]},{cluster_name,<<"rabbit@rabbitmq1">>},{partitions,[]}]
    ...done.# rabbitmq3 的结果:
    Cluster status of node rabbit@rabbitmq3 ...
    [{nodes,[{disc,[rabbit@rabbitmq1,rabbit@rabbitmq2,rabbit@rabbitmq3]}]},{running_nodes,[rabbit@rabbitmq2,rabbit@rabbitmq1,rabbit@rabbitmq3]},{cluster_name,<<"rabbit@rabbitmq1">>},{partitions,[]}]
    ...done.
    

    此时集群配置成功

四、测试

可以可以启用 RabbitMQ 可视化web管理插件,更直观的看到集群状态,也方便测试
三台服务器都要开启

rabbitmq-plugins enable rabbitmq_management
systemctl restart rabbitmq-server

通过IP地址加端口号访问,端口号为 15672
如:192.168.152.71:15672,默认的用户名:guest,密码:guest
在这里插入图片描述
可以再其中一台添加用户,看其它几台是否有变化,有则配置成功
在这里插入图片描述


http://www.ppmy.cn/devtools/163599.html

相关文章

微信小程序读取写入NFC文本,以及NFC直接启动小程序指定页面

一、微信小程序读取NFC文本(yyy优译小程序实现),网上有很多通过wx.getNFCAdapter方法来监听读取NFC卡信息,但怎么处理读取的message文本比较难找,现用下面方法来实现,同时还解决几个问题,1、在回调方法中this.setData不更新信息,因为this的指向问题,2、在退出页面时,…

GCN从理论到实践——基于PyTorch的图卷积网络层实现

Hi&#xff0c;大家好&#xff0c;我是半亩花海。图卷积网络&#xff08;Graph Convolutional Network, GCN&#xff09;是一种处理图结构数据的深度学习模型。它通过聚合邻居节点的信息来更新每个节点的特征表示&#xff0c;广泛应用于社交网络分析、推荐系统和生物信息学等领…

记一次生成core_dump文件的调查记录

1. 启用 core dump 在默认情况下&#xff0c;Linux 可能不生成 core dump 文件。要启用它&#xff0c;需要调整 shell 的 core dump 限制&#xff1a; 查看当前限制&#xff0c;执行命令&#xff1a; ulimit -c如果返回值为 0&#xff0c;则表示禁用了 core dump。 启用 co…

快速列出MS Word中所有可用字体

Word中有很多字体&#xff0c;虽然在字体下拉列表中提供了字体的样例&#xff0c;但是并不全面&#xff0c;例如使用Batang字体的话&#xff0c;数字会显示成什么效果&#xff0c;就无法直观的看到。 打开Word应用程序&#xff0c;新建一个空白文档&#xff0c;按AltF11打开VBE…

汽车悬架系统技术演进:从被动到全主动的革新之路(主动悬架类型对比)

在汽车工业的百年发展史中&#xff0c;悬架系统始终是平衡车辆性能与舒适性的关键战场。随着消费者对驾乘体验要求的不断提升&#xff0c;传统被动悬架已难以满足中高端车型的需求&#xff0c;而半主动与全主动悬架技术的崛起&#xff0c;正在重塑行业格局。本文将深入解析三大…

C++和OpenGL实现3D游戏编程【连载23】——几何着色器和法线可视化

欢迎来到zhooyu的C++和OpenGL游戏专栏,专栏连载的所有精彩内容目录详见下边链接: 🔥C++和OpenGL实现3D游戏编程【总览】 1、本节实现的内容 上一节课,我们在Blend软件中导出经纬球模型时,遇到了经纬球法线导致我们在游戏中模型光照显示问题,我们在Blender软件中可以通过…

【运维工具】今天就聊APM

文章目录 什么是APM?**什么是 APM&#xff1f;****APM 的核心目标****APM 的主要功能****APM 的应用场景****APM 的分类****APM 的优势****总结** APM框架有哪些&#xff1f;一、开源 APM 框架1. **Pinpoint**2. **SkyWalking**3. **Zipkin**4. **Jaeger**5. **OpenTelemetry*…

【压力测试】

压力测试 一、背景与现状1、引言2. 压力测试与不可忽视的α3. 制度演变&#xff1a;从公募基金到理财产品4. 行业实践仍处于早期阶段5. 理财产品压力测试的优化路径 二、压力测试介绍1. 压力测试的定义2. 压力测试的步骤 一、背景与现状 1、引言 20世纪末&#xff0c;随着世界…