目录

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添加集群成功,查看队列。

推荐阅读

评论可见,请评论后查看内容,谢谢!!!
 您阅读本篇文章共花了: