window单机搭建RabbitMQ多节点集群(超详细)
一、前言
在学习过程中,由于某种奇葩原因,电脑装不了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盘下 的配置文件
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实现高可用性及负载均衡代理,将在下一篇文章发表关于集群的其它配置。
配置过程中有任何问题或者本文有不足之处,欢迎评论区留言!!!