目录
2.3 将Rabbitmq-1、Rabbitmq-2作为内存节点加⼊mq节点集群中
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"}' [root@rabbitmq-1 ~]# rabbitmqctl set_policy ha-all "^" '{"ha-mode":"all"}' [root@rabbitmq-2 ~]# rabbitmqctl set_policy ha-all "^" '{"ha-mode":"all"}' |