RabbitMQ集群部署

目录

1.环境准备

1.1关闭防火墙和selinux

1.2本地解析

1.3安装rabbitmq软件

1.4启动服务

1.5创建用户

1.6开启用户远程登录

 2.开始部署集群(三台机器都操作)

2.1首先创建好数据存放目录和·日志存放目录

2.2 拷贝erlang.cookie

2.3 将Rabbitmq-1、Rabbitmq-2作为内存节点加⼊mq节点集群中

2.4 查看集群状态

​编辑3.登录rabbitmq web管理控制台

3.RabbitMQ镜像集群配置

3.1创建镜像集群

3.2添加集群成功,查看队列。


RabbitMQ的集群节点包括内存节点、磁盘节点。顾名思义内存节点就是将所有数据放在内存,磁盘节点将数据放在磁盘。如果在投递消息时,打开了消息的持久化,那么即使是内存节点,数据还是安全的放在磁盘。

一个rabbitmq集 群中可以共享 user,vhost,queue,exchange等,所有的数据和状态都是必须在所有节点上复制的。

1 内存节点:只保存状态到内存(一个例外的情况是:持久的queue的持久内容将被保存到disk)

2 磁盘节点:保存状态到内存和磁盘。

内存节点虽然不写入磁盘,但是它执行比磁盘节点要好。集群中,只需要一个磁盘节点来保存状态 就足够了

如果集群中只有内存节点,那么不能停止它们,否则所有的状态,消息等都会丢失。

1.环境准备

192.168.18.135    rabbitmq
192.168.18.137    rabbitmq-1
192.168.18.138    rabbitmq-2

1.1关闭防火墙和selinux

1.2本地解析

[root@rabbitmq ~]# vim /etc/hosts

1.3安装rabbitmq软件

安装依赖
[root@rabbitmq ~]# yum install -y epel-release gcc-c++ unixODBC unixODBC-devel openssl-devel ncurses-devel
yum安装erlang
[root@rabbitmq ~]# curl -s https://packagecloud.io/install/repositories/rabbitmq/erlang/script.rpm.sh | sudo bash
[root@rabbitmq ~]# yum install erlang-21.3.8.21-1.el7.x86_64
安装rabbitmq
https://github.com/rabbitmq/rabbitmq-server/releases/tag/v3.7.10
[root@rabbitmq ~]# yum install rabbitmq-server-3.7.10-1.el7.noarch.rpm

1.4启动服务

[root@rabbitmq ~]# systemctl daemon-reload
[root@rabbitmq ~]# systemctl start rabbitmq-server
[root@rabbitmq ~]# systemctl enable rabbitmq-server
启动方式二:
[root@rabbitmq ~]# /sbin/service rabbitmq-server status  ---查看状态
[root@rabbitmq ~]# /sbin/service rabbitmq-server start   ---启动
每台都操作开启rabbitmq的web访问界面:
[root@rabbitmq ~]# rabbitmq-plugins enable rabbitmq_management

1.5创建用户

注意:在一台机器操作
添加用户和密码
[root@rabbitmq ~]# rabbitmqctl add_user newrain 123456
Creating user "newrain" ...
...done.
这是为管理员
[root@rabbitmq ~]# rabbitmqctl set_user_tags newrain administrator
Setting tags for user "newrain" to [administrator] ...
...done.
查看用户
[root@rabbitmq ~]# rabbitmqctl list_users
Listing users ...
guest	[administrator]
newrain	[administrator]
...done.

1.6开启用户远程登录

[root@rabbitmq ~]# cd /etc/rabbitmq/
[root@rabbitmq rabbitmq]# cp /usr/share/doc/rabbitmq-server-3.7.10/rabbitmq.config.example /etc/rabbitmq/rabbitmq.config
[root@rabbitmq rabbitmq]# ls
enabled_plugins  rabbitmq.config
[root@rabbitmq rabbitmq]# vim rabbitmq.config

 2.开始部署集群(三台机器都操作)

2.1首先创建好数据存放目录和·日志存放目录

[root@rabbitmq ~]# mkdir -p /data/rabbitmq/data
[root@rabbitmq ~]# mkdir -p /data/rabbitmq/logs
[root@rabbitmq ~]# chmod 777 -R /data/rabbitmq
[root@rabbitmq ~]# chown rabbitmq.rabbitmq /data/ -R
创建配置文件:
[root@rabbitmq ~]# vim /etc/rabbitmq/rabbitmq-env.conf
[root@rabbitmq ~]# cat /etc/rabbitmq/rabbitmq-env.conf
RABBITMQ_MNESIA_BASE=/data/rabbitmq/data
RABBITMQ_LOG_BASE=/data/rabbitmq/logs
重启服务
[root@rabbitmq ~]# systemctl restart rabbitmq-server

2.2 拷贝erlang.cookie

Rabbitmq的集群是依附于erlang的集群来⼯作的,所以必须先构建起erlang的集群景象。Erlang的集群中,各节点是经由过程⼀个magic cookie来实现的,这个cookie存在/var/lib/rabbitmq/.erlang.cookie中,⽂件是400的权限。所以必须保证各节点cookie⼀致,不然节点之间就⽆法通信。

[root@rabbitmq ~]# cat /var/lib/rabbitmq/.erlang.cookie
HOUCUGJDZYTFZDSWXTHJ
⽤scp的⽅式将rabbitmq-1节点的.erlang.cookie的值复制到其他两个节点中。
[root@rabbitmq ~]# scp /var/lib/rabbitmq/.erlang.cookie root@192.168.18.137:/var/lib/rabbitmq/
[root@rabbitmq ~]# scp /var/lib/rabbitmq/.erlang.cookie root@192.168.18.138:/var/lib/rabbitmq/

2.3 将Rabbitmq-1、Rabbitmq-2作为内存节点加⼊mq节点集群中

在mq-1、mq-2执⾏如下命令:
[root@rabbitmq-1 ~]# systemctl restart rabbitmq-server
[root@rabbitmq-1 ~]# rabbitmqctl stop_app  #停止节点
[root@rabbitmq-1 ~]# rabbitmqctl reset   #如果有数据需要重置,没有则不用
[root@rabbitmq-1 ~]# rabbitmqctl join_cluster --ram rabbit@rabbitmq  #添加到磁盘节点
Clustering node 'rabbit@rabbitmq-1' with 'rabbit@rabbitmq' ...
[root@rabbitmq-1 ~]# rabbitmqctl start_app  #启动节点
Starting node 'rabbit@rabbitmq' ...

[root@rabbitmq-2 ~]# systemctl restart rabbitmq-server
[root@rabbitmq-2 ~]# rabbitmqctl stop_app
Stopping node 'rabbit@rabbitmq-2' ...
[root@rabbitmq-2 ~]# rabbitmqctl reset
Resetting node 'rabbit@rabbitmq-3' ...
[root@rabbitmq-2 ~]# rabbitmqctl join_cluster --ram rabbit@rabbitmq
Clustering node 'rabbit@rabbitmq-3' with 'rabbit@rabbitmq' ...
[root@rabbitmq-2 ~]# rabbitmqctl start_app
Starting node 'rabbit@rabbitmq-2'

注:(1)默认rabbitmq启动后是磁盘节点,在这个cluster命令下,mq-1和mq-2是内存节点,
mq是磁盘节点。
(2)如果要使mq-1、mq-2都是磁盘节点,去掉--ram参数即可。
(3)如果想要更改节点类型,可以使⽤命令rabbitmqctl change_cluster_node_type
disc(ram),前提是必须停掉rabbit应用。

#如果有需要使用磁盘节点加入集群
 [root@rabbitmq-1 ~]# rabbitmqctl join_cluster  rabbit@rabbitmq
 [root@rabbitmq-2 ~]# rabbitmqctl join_cluster  rabbit@rabbitmq

2.4 查看集群状态

[root@rabbitmq ~]# rabbitmqctl cluster_status

3.登录rabbitmq web管理控制台

打开浏览器输⼊http://192.168.18.135:15672,

账号:guest

密码:123456

 出现上述图中信息,那么我们的集群就部署好了。

3.RabbitMQ镜像集群配置

上面已经完成RabbitMQ默认集群模式,但并不保证队列的高可用性,尽管交换机、绑定这些可以复制到集群里的任何一个节点,但是队列内容不会复制。但队列节点宕机直接导致该队列无法应用,只能等待重启,所以要想在队列节点宕机或故障也能正常应用,就要复制队列内容到集群里的每个节点,必须要创建镜像队列。

3.1创建镜像集群

rabbitmqctl set_permissions  ".*" ".*" ".*"         (后面三个”*”代表用户拥有配置、写、读全部权限)

[root@rabbitmq ~]# rabbitmqctl set_policy  ha-all "^" '{"ha-mode":"all"}'
Setting policy "ha-all" for pattern "^" to "{"ha-mode":"all"}" with priority "0" for vhost "/" ...

[root@rabbitmq-1 ~]# rabbitmqctl set_policy  ha-all "^" '{"ha-mode":"all"}'
Setting policy "ha-all" for pattern "^" to "{"ha-mode":"all"}" with priority "0" for vhost "/" ...

[root@rabbitmq-2 ~]# rabbitmqctl set_policy  ha-all "^" '{"ha-mode":"all"}'
Setting policy "ha-all" for pattern "^" to "{"ha-mode":"all"}" with priority "0" for vhost "/" ...

3.2添加集群成功,查看队列。

RabbitMQ是一款基于AMQP协议的开源消息队列系统,它可以让应用程序之间进行可靠的异步消息传递。 RabbitMQ支持多个节点的分布式部署,以提高可用性和性能。 以下是RabbitMQ集群部署的步骤: 1. 安装Erlang和RabbitMQ 首先需要安装Erlang和RabbitMQ。可以从官方网站下载安装包并按照说明进行安装。 2. 创建配置文件 在每个节点上,需要创建一个配置文件,该文件将指定节点的名称、IP地址、端口、群集节点等信息。可以使用默认配置文件,并在该文件中添加以下内容: ``` cluster_formation.peer_discovery_backend = rabbit_peer_discovery_classic_config cluster_formation.classic_config.nodes.1 = rabbit@node1 cluster_formation.classic_config.nodes.2 = rabbit@node2 cluster_formation.classic_config.nodes.3 = rabbit@node3 ``` 其中,`rabbit@node1`、`rabbit@node2`、`rabbit@node3`是节点的名称,需要根据实际情况进行更改。 3. 启动节点 在每个节点上启动RabbitMQ服务: ``` rabbitmq-server -detached ``` 4. 加入群集 在每个节点上,使用以下命令将节点加入群集: ``` rabbitmqctl join_cluster rabbit@node1 ``` 其中,`rabbit@node1`是群集中的一个节点,需要根据实际情况进行更改。 5. 启动群集 在任一节点上,使用以下命令启动群集: ``` rabbitmqctl start_app ``` 6. 验证群集状态 使用以下命令验证群集状态: ``` rabbitmqctl cluster_status ``` 如果输出内容包含所有节点的名称,则表示群集已经成功部署。 注意:在RabbitMQ集群中,每个队列都将在某个节点上运行。如果某个节点宕机,该节点上的队列将无法访问。因此,需要使用镜像队列来确保数据的可靠性。具体的做法是将队列的镜像复制到其他节点上,以确保在某个节点宕机时,队列可以在其他节点上运行。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值