Windows环境下 RabbitMQ集群配置

一、在集群机器上安装erlang环境、安装rabbitmq;

 

二、 假设,192.168.10.111的节点名称为 rabbit@H1-PC,192.168.10.112的节点名称为 rabbit@H2-PC

1.分别在两台机器的rabbitmq数据、日志文件所在路径下(本文为C:\Users\Administrator\AppData\Roaming\RabbitMQ),创建集群配置文件rabbitmq.config。

rabbitmq.config是一个标准的erlang配置文件。它必须符合erlang配置文件的标准。

它既有默认的目录,也可以在rabbitmq-env.conf文件中配置。

内容为(包括最后的.):

[{rabbit,[{cluster_nodes, ['rabbit@app118', 'rabbit@app119']}]}].

 

2.分别配置两台机器的host(C:\Windows\System32\drivers\etc目录下)。

111:

192.168.10.111 H1-PC

192.168.10.112 H2-PC

 

112:

192.168.10.112 H2-PC

192.168.10.111 H1-PC

 

3.分别在两台机器的rabbitmq数据、日志文件所在路径下(本文为C:\Users\Administrator\AppData\Roaming\RabbitMQ),创建rabbitmq环境变量的配置文件rabbitmq-env.conf。

192.168.10.111的rabbitmq-env.conf内容为:

NODENAME=rabbit@H1-PC

NODE_IP_ADDRESS=192.168.10.111

NODE_PORT=5672

RABBITMQ_MNESIA_BASE=C:\Users\Administrator\AppData\Roaming\RabbitMQ\db

RABBITMQ_LOG_BASE=C:\Users\Administrator\AppData\Roaming\RabbitMQ\log

 

192.168.10.112的rabbitmq-env.conf内容为:

NODENAME=rabbit@H2-PC

NODE_IP_ADDRESS=192.168.10.112

NODE_PORT=5672

RABBITMQ_MNESIA_BASE=C:\Users\Administrator\AppData\Roaming\RabbitMQ\db

RABBITMQ_LOG_BASE=C:\Users\Administrator\AppData\Roaming\RabbitMQ\log

 

4.将192.168.10.111的C:\Users\Administrator文件夹下的.erlang.cookie文件替换掉

192.168.10.112 C:\Users\Administrator和C:\Windows下的该文件(该文件是集群节点进行通信的验证密钥,所有节点必须一致。反过来亦可)。

 

5.重启两台机器的rabbitmq。

(1)192.168.10.112,在控制台D:\RabbitMQ Server\rabbitmq_server-2.8.1\sbin 路径下分别执行以下语句:

 

rabbitmqctl stop_app

rabbitmqctl reset

rabbitmqctl start_app

 

 (2) 192.168.10.111,在控制台D:\RabbitMQServer\rabbitmq_server-2.8.1\sbin路径下分别执行以下语句:

 

  rabbitmqctl stop_app

 

  rabbitmqctl reset

 

  rabbtimqctl join_cluster rabbit@H2-PC

 

  rabbitmqctl start_app

 

  上述命令先停掉rabbitmq应用,reset集群状态,然后调用cluster命令,将H1-PC连接到H2-PC,使两者成为一个集群,最后重启rabbitmq应用。在这个cluster命令下,H1-PC是内存节点,H2-PC是磁盘节点(RabbitMQ启动后,默认是磁盘节点)。

 

     如果要使H1-PC在集群里也是磁盘节点,那么更改上述第3句如下:

 

rabbitmqctl cluster rabbit@H2-PC rabbit@H1-PC

 

     只要在节点列表里包含了自己,它就成为一个磁盘节点。在RabbitMQ集群里,必须至少有一个磁盘节点存在。

 

 

6.在H1-PC和H2-PC上,运行rabbitmqctl cluster_status命令查看集群状态.

 

Cluster status of node 'rabbit@H1-PC'...

[{nodes,[{disc,['rabbit@H2-PC']},{ram,['rabbit@H1-PC']}]},

 {running_nodes,['rabbit@H2-PC','rabbit@H1-PC']}]

...done.

转载于:https://www.cnblogs.com/hegx/p/6097147.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值