Rabbitmq集群

根据项目需要,三台机器搭建一个rabbitmq集群,10.10.10.1(虚拟IP,下同)为主节点,10.10.10.2和10.10.10.3为从节点。

1、安装erlang,该软件包是rabbitMQ依赖软件包,三台机器同步安装。

将安装包otp_src_18.3.tar上传到三台服务器的data目录下解压并更改文件名为erlang。

|-----------------------------------------------------|
| tar -xvf otp_src_18.3.tar.gz mv otp_src_18.3 erlang |

安装erlang需要的依赖库,包括gcc,kernel-devel,ncurses-devel,openssl-devel,unixODBC-devel。

|-----------------------------------------------------------------------------------------|
| yum -y install make gccgcc-c++ kernel-devel m4 ncurses-developenssl-develunixODBC-devel |

2、进入解压后的源码目录,编译安装erlang。

|-------------------------------------------------------------------------------------|
| cd /data/erlang ./configure --prefix=/data/erlang --without-javac make make install |

3、安装rabbitMQ

3.1将rabbitMQ安装包上传到三台服务器的/data下并解压。

|----------------------------------------------------|
| tar -xvf rabbitmq-server-generic-unix-3.6.6.tar.xz |

3.2编辑/etc/profile文件

|------------------|
| vim /etc/profile |

3.3修改文件内容

|------------------------------------------------------------------------------------------------------------------------------------------|
| export PATH=PATH:/data/erlang/bin export PATH=PATH:/data/rabbitmq_server-3.6.6 PATH=/data/rabbitmq_server-3.6.6/sbin:$PATH export PATH |

3.4保存该文件退出

3.5重新载入环境变量

|---------------------|
| source /etc/profile |

4、将rabbitmq_server-3.6.6/ebin目录下rabbit.app中loopback_users里的<<"guest">>删除,安装完rabbitMQ后,可以使用用户名密码都为guest的用户登录rabbitMQ的web监控页面。

5、启动rabbitMQ服务。

启动三台机器上的rabbitmq服务

|--------------------------------------------------------------------------------------|
| cd /data/rabbitmq_server-3.6.6/sbin/ nohup ./rabbitmq-server >log.log 2>err.log & |

6、安装rabbitMQ的web监控,三台机器同步安装。

|------------------------------------------------------------------------------------|
| cd /data/rabbitmq_server-3.6.6/sbin/ ./rabbitmq-plugins enable rabbitmq_management |

用户可以通过访问rabbitMQ所在机器的IP:15672,访问rabbitMQ的监控网页,使用用户名密码都为guest的用户登录。如果不能访问的话,需要将rabbitMQ所在服务器的防火墙关闭,关闭防火墙的语句:

|---------------------------------------------------------------------------------|
| sudosystemctl stop firewalld.service&&sudosystemctl disable firewalld.service |

关闭以后就能访问了。

7、创建软连接

ln -s /data/rabbitmq_server-3.6.6/sbin/rabbitmqctl rabbitmqctl

8、同步.erlang.cookee

.erlang.cookee在/root下,是一个隐藏文件。进入主节点10.10.10.1下,查看.erlang.cookee,修改从节点10.10.10.2和10.10.10.3的.erlang.cookee,与主节点保持一致即可。

9、重启rabbitmq服务

在从节点上执行

rabbitmqctl stop_app

rabbitmqctl join_cluster rabbit@txla100140

rabbitmqctl start_app

两台从节点全部加入集群后,登录http://10.10.10.1:15672/#/,看到下图,成功。

相关推荐
龙仔72513 小时前
离线安装rabbitmq全流程
分布式·rabbitmq·ruby
hoho不爱喝酒2 天前
微服务 RabbitMQ 组件的介绍、安装与使用详解
微服务·rabbitmq·ruby
noravinsc9 天前
python 使用rabbitmq
python·rabbitmq·ruby
q5673152312 天前
利用Ruby的Typhoeus编写爬虫程序
开发语言·爬虫·scrapy·ruby
Thanks_ks12 天前
探秘 Ruby 与 JavaScript:动态语言的多面风采
javascript·ruby·应用场景·动态语言·语法特性·开发体验·任务管理系统
碣石潇湘无限路13 天前
【技术】Ruby 生态概念速查表,通过对比nodejs生态(入门)
开发语言·经验分享·笔记·后端·node.js·ruby
weifexie13 天前
ruby高级语法
开发语言·ruby
weifexie14 天前
ruby可变参数
开发语言·前端·ruby
朴拙数科16 天前
gevent 高并发、 RabbitMQ 消息队列、Celery 分布式的案例和说明
分布式·rabbitmq·ruby
weifexie16 天前
ruby超高级语法
开发语言·后端·ruby