window下单机搭建RabbitMQ多节点集群(超详细)

window下单机搭建RabbitMQ多节点集群(超详细)

window单机搭建RabbitMQ多节点集群(超详细)
一、前言
二、需求
三、准备工作
四、多节点搭建
1)复制三份RabbitMQ,区分名字
2)新增xxx.config文件(以rabbitmq_server-3.8.4-1 为例)
3)修改 abbitmq-env.bat 文件(以rabbitmq_server-3.8.4-1 为例)
4)修改 rabbitmq-server.bat 文件(以rabbitmq_server-3.8.4-1 为例)
5)启动方式一测试(start 命令)
6)启动方式二测试(-detached 命令)
7) 两种启动方式区别
五、 启动rabbit1、rabbit2、rabbit3
1)分别以后台形式启动三个RabbitMQ服务
六、将 rabbit2,rabbit3 加入集群
1)关闭 rabbit2
2) 将 rabbit2 加入 rabbit1
3) 打开15673管理后台验证
4)查看集群状态
5)各节点状态
七、退出集群
1)将 rabbit2 退出集群
2)打开管理后台
八、bat脚本启动MQ服务
1)脚本代码(窗口运行方式)
2)脚本代码(后台

 

一、前言
在学习过程中,由于某种奇葩原因,电脑装不了linux虚拟机,查阅关于 rabbitmq集群搭建 资料大多都是基于linux系统,window下单机搭建 文章数量较少,搞了好几天总算顺利搭建,希望对大家有帮助


版本说明

RabbitMQ使用版本是3.8.4
Erlang使用版本是 23.0
二、需求
在一台window系统电脑上搭建多节点RabbitMQ集群,节点名称和端口的对应关系为:

 rabbit1        15673
 rabbit2        15674
 rabbit3        15675

 


三、准备工作
安装 Erlang
安装 RabbitMQ
确保以上2步安装成功,以及mq可以开启并访问到管理页面(具体可查RabbitMQ安装步骤,这里不过多阐述)
四、多节点搭建
1)复制三份RabbitMQ,区分名字

 

 

 


2)新增xxx.config文件(以rabbitmq_server-3.8.4-1 为例)
在 /etc/ 下新增 rabbitmq-node1.config,加入以下配置(三个安装目录下都要新增,端口分别为5673,5674,5675)

[ {
  rabbit,
  [ {
    tcp_listeners,
    [ {"0.0.0.0" ,5673}]
  }]
},{
  rabbitmq_management,
  [ {
    listener,
    [
      {port , 15674},
      {ip , "127.0.0.1"},
      {ssl,false}
    ]
  }]
}].

 


3)修改 abbitmq-env.bat 文件(以rabbitmq_server-3.8.4-1 为例)
在 abbitmq-env.bat 文件16行加入以下配置(其余两个也要修改)

//这一行是指定使用我们刚刚 /etc/ 下创建的config文件,不指定会默认使用 C盘下 的配置文件

    //这一行是指定使用我们刚刚 /etc/ 下创建的config文件,不指定会默认使用 C盘下 的配置文件
    set RABBITMQ_CONFIG_FILE=!RABBITMQ_HOME!\etc\rabbitmq-node1 
    set RABBITMQ_NODENAME=rabbit1

 

配置截图如下(橙色部分为节点名称,注意不能重复)

 

 

 


4)修改 rabbitmq-server.bat 文件(以rabbitmq_server-3.8.4-1 为例)
在 rabbitmq-server.bat 文件27行加入以下配置(其余两个也要修改)

    set RABBITMQ_NODE_PORT=5673
    set RABBITMQ_DIST_PORT=15673

 


配置截图如下(橙色部分为端口号,注意不能重复)

 

 

 


5)启动方式一测试(start 命令)
4.1 以管理员身份运行cmd,cd到 rabbitmq_server-3.8.4-1的sbin目录下,执行以下命令(更改配置文件需要执行remove和install使配置生效)

rabbitmq-service remove
rabbitmq-service install
rabbitmq-server start
实例截图如下

 

 

 

4.2 测试访问管理页面(示例端口:15763)
浏览器输入 localhost:15763/#/ ,出现这个管理页面说明配置成功

 

 

 


6)启动方式二测试(-detached 命令)
5.1 以管理员身份运行cmd,cd到 rabbitmq_server-3.8.4-1的sbin目录下,执行以下命令(更改配置文件需要执行remove和install使配置生效)

rabbitmq-service remove
rabbitmq-service install
rabbitmq-server -detached
5.2 测试访问管理页面(示例端口:15763)
浏览器输入 localhost:15763/#/ ,同样可以看到这个页面

 

 

 


7) 两种启动方式区别
start :关闭该cmd窗口,服务即关闭
-detached :关闭窗口,服务依然在,在任务管理器将 erl.exe 进程关闭即可关闭服务
五、 启动rabbit1、rabbit2、rabbit3
1)分别以后台形式启动三个RabbitMQ服务
方便演示单机集群的搭建,我们将上一步开启的服务全部关掉,分别进入rabbitmq_server-3.8.4-1、rabbitmq_server-3.8.4-2、rabbitmq_server-3.8.4-3 的 sbin 目录,执行命令

rabbitmq-server -detached

D:\tools\RabbitMQ Server\rabbitmq_server-3.8.4-1\sbin>rabbitmq-server -detached    //服务1
D:\tools\RabbitMQ Server\rabbitmq_server-3.8.4-2\sbin>rabbitmq-server -detached //服务2
D:\tools\RabbitMQ Server\rabbitmq_server-3.8.4-3\sbin>rabbitmq-server -detached //服务3

 


浏览器地址栏输入 http://localhost:15673/#/,在管理后台可以看到,rabbit1 已经成功启动了.

 

 

 

浏览器地址栏输入 http://localhost:15674/#/,在管理后台可以看到,rabbit2 已经成功启动了

 

 

 


浏览器地址栏输入 http://localhost:15675/#/,在管理后台可以看到,rabbit3 已经成功启动了

 

 

 


六、将 rabbit2,rabbit3 加入集群
1)关闭 rabbit2
在rabbitmq_server-3.8.4-2的sbin目录下
执行命令 rabbitmqctl stop_app

D:\tools\RabbitMQ Server\rabbitmq_server-3.8.4-2\sbin>rabbitmqctl stop_app
Stopping rabbit application on node rabbit2@DESKTOP-IB5K0.. ... //成功关闭提示

2) 将 rabbit2 加入 rabbit1
执行命令 rabbitmqctl join_cluster rabbit1

D:\tools\RabbitMQ Server\rabbitmq_server-3.8.4-2\sbin>rabbitmqctl join_cluster rabbit1
Clustering node rabbit2@DESKTOP-IB5K0.. with rabbit1  //成功提示

 


3) 打开15673管理后台验证

可以看到 rabbit2 已经加入进来,但未启动

 

 

将 rabbit2 启动起来,执行命令 rabbitmqctl start_app

D:\tools\RabbitMQ Server\rabbitmq_server-3.8.4-2\sbin>rabbitmqctl start_app
Starting node rabbit2@DESKTOP-IB5K0CG ... //成功启动提示

 


可以看到状态已经更改为绿色

 

 

同理,进入rabbitmq_server-3.8.4-3的sbin目录下重复以上步骤将 rabbit3 加入 rabbit1 集群
打开管理后台验证:

 

 


4)查看集群状态
在 sbin目录下执行命令
rabbitmqctl cluster_status
集群名称为 rabbit1,且有三个节点正在运行

 

 


5)各节点状态

 

 


七、退出集群
1)将 rabbit2 退出集群
rabbitmq-server -detached (已经启动可以忽略这一步)
rabbitmqctl stop_app (关闭节点)
rabbitmqctl reset

 

 

 


2)打开管理后台

 

 

 


八、bat脚本启动MQ服务
搭建过程每次关闭服务后,都需要重新cd进文件目录,输入一堆命令启动服务,十分繁琐,于是决定使用bat脚本提前写好命令,一键启动RabbitMQ服务

1)脚本代码(窗口运行方式)

@echo off
:获取管理员权限
%1 mshta vbscript:CreateObject("Shell.Application").ShellExecute("cmd.exe","/c %~s0 ::","","runas",1)(window.close)&&exit
:保持当前目录下运行
cd /d "%~dp0"

@echo. start RabbitMQ...1
@echo off

cmd /k "cd /d D:\tools\RabbitMQ Server\rabbitmq_server-3.8.4-1\sbin&&rabbitmq-service remove&&rabbitmq-service install&&rabbitmq-server start"

exit
echo "^_^ Close the Window To Stop" & pause > nul

 


代码截图

 

 

 


bat文件

 

 

 


双击bat文件一键启动MQ服务

 

 

 

 

2)脚本代码(后台运行方式)

@echo off
:获取管理员权限
%1 mshta vbscript:CreateObject("Shell.Application").ShellExecute("cmd.exe","/c %~s0 ::","","runas",1)(window.close)&&exit
:保持当前目录下运行
cd /d "%~dp0"

@echo. start RabbitMQ...3
@echo off

cmd /k "cd /d D:\tools\RabbitMQ Server\rabbitmq_server-3.8.4-1\sbin&&rabbitmq-server -detached"

exit
echo "^_^ Close the Window To Stop" & pause > nul

 


配置三份

 

 

 

九、总结
至此,普通集群已初步搭建,这种集群可以提高 RabbitMQ 的消息吞吐能力,但是无法保证高可用,因为一旦一个 RabbitMQ 实例挂了,消息就没法访问了,如果消息队列做了持久化,那么等 RabbitMQ 实例恢复后,才可以继续访问;如果消息队列没做持久化,那么消息就丢了。基于这种情况,我们可以将队列设置为镜像队列来解决。后续将会增加镜像队列配置以及通过HAProxy实现高可用性及负载均衡代理,将在下一篇文章发表关于集群的其它配置。

配置过程中有任何问题或者本文有不足之处,欢迎评论区留言!!!

posted @ 2022-08-04 10:26  邃蓝星空  阅读(1500)  评论(1编辑  收藏  举报