RabbitMQ 集群安装过程详解
一.安装Erlang
1.rabbitMQ是基于erlang的,所以首先必须配置erlang环境。
从erlang官网下载 otp 18.3。下载链接:http://erlang.org/download/otp_src_18.3.tar.gz
linux 可以使用wget http://erlang.org/download/otp_src_18.3.tar.gz 下载
2.解压并配置,编译,安装过程
# tar zvxf otp_src_18..tar.gz
# mv otp_src_18./ otp
# cd otp
# ./configure --prefix=/home/erlang --without-javac
报错:
configure: error: No curses library functions found
configure: error: /bin/sh '/root/otp/erts/configure' failed for erts
# yum -y install ncurses-devel
# ./configure --prefix=/home/erlang --without-javac
报错
*********************************************************************
********************** APPLICATIONS DISABLED **********************
*********************************************************************
crypto : No usable OpenSSL found
jinterface : Java compiler disabled by user
odbc : ODBC library - link check failed
orber : No C++ compiler found
ssh : No usable OpenSSL found
ssl : No usable OpenSSL found
*********************************************************************
# yum list | grep ssl
# yum install openssl-devel
# ./configure --prefix=/home/erlang --without-javac
报错
*********************************************************************
********************** APPLICATIONS DISABLED **********************
*********************************************************************
jinterface : Java compiler disabled by user
odbc : ODBC library - link check failed
orber : No C++ compiler found
*********************************************************************
# yum list | grep ODBC
# yum install unixODBC-devel
# ./configure --prefix=/home/erlang --without-javac
报错
*********************************************************************
********************** APPLICATIONS DISABLED **********************
*********************************************************************
jinterface : Java compiler disabled by user
orber : No C++ compiler found
*********************************************************************
# yum install gcc-c++
# ./configure --prefix=/home/erlang --without-javac
# make
# make install
安装完成!
测试Erlang是否安装正确
# /home/erlang/bin/erl
Erlang/OTP [erts-6.0] [source] [-bit] [async-threads:] [hipe] [kernel-poll:false] Eshell V6. (abort with ^G)
> EvenN = lists:filter (fun (N) -> N rem == end, lists:seq(,)).
[,,,,,,,,,,,,,,,,,,,,,
,,,,,,,|...]
> halt().
有几种退出Erlang Shell的方法
命令方式1:执行init:stop().
命令方式2:执行halt().
快捷键方式1:Control+C 然后选a
快捷键方式2:Control+G 然后按q
3.在PATH环境变量添加erlang的bin路径,以便执行。
vi /etc/profile ERL_HOME=/home/erlang export PATH=$PATH:/home/erlang/bin
最后 source /etc/profile
【安装总结】
从源码编译安装Erlang,有两个库或工具是必须的:
一是完整的GCC编译器环境
二是Ncurses开发库
还有一些库或工具,如果没有它们,在编译配置时会出现警告信息,而且可能不能通过配置。这些库有:
1)OpenSSL开发库
2)ODBC开发库
3)Java编译器
二.安装RabbitMQ Server
rpm -Uvh https://packages.erlang-solutions.com/erlang-solutions-1.0-1.noarch.rpm
rpm -Uvh http://download.fedoraproject.org/pub/epel/6/i386/epel-release-6-8.noarch.rpm
配置epel源的目的是为了安装socat
wget http://www.rabbitmq.com/releases/rabbitmq-server/v3.6.4/rabbitmq-server-3.6.4-1.noarch.rpm
yum install rabbitmq-server-3.6.-.noarch.rpm
#使用yum安装即可把依赖包一起安装好
wget http://www.rabbitmq.com/releases/rabbitmq-server/v3.6.4/rabbitmq-server-3.6.4-1.noarch.rpm
rpm -ivh --nodeps rabbitmq-server-3.6.-.noarch.rpm
--nodeps 设置后,不需要重新按照erlang,否则会现在安装最新的erlang语言依赖。
创建用户、设置角色、权限控制
启动与停止服务:
# /sbin/service rabbitmq-server stop
# /sbin/service rabbitmq-server start
# rabbitmqctl status 测试正确
创建用户并设置角色:
$sudo rabbitmqctl add_user huacw
赋予其administrator角色:
$sudo rabbitmqctl set_user_tags huacw administrator
查询用户列表:
$sudo rabbitmqctl list_users
为用户赋权(huacw用户赋予 根目录权限):
$sudo rabbitmqctl set_permissions -p / huacw '.*' '.*' '.*'
该命令使用户huacw具有 / 这个 根目录 中所有资源的 配置、写、读权限以便管理其中的资源
查看用户权限:
$sudo rabbitmqctl list_user_permissions huacw
三、插件管理
查看插件列表及状态
进入/usr/lib/rabbitmq/bin
./rabbitmq-plugins list
启用插件(web管理插件为例):
./rabbitmq-plugins enable rabbitmq_management
禁用某插件
./rabbitmq-plugins disable rabbitmq_management
三.卸载
查找安装文件
#rpm -qa|grep rabbitmq
rabbitmq-server-3.6.-.noarch
卸载
#rpm -e --nodeps rabbitmq-server-3.6.-.noarch
查找erlang安装文件
#rpm -qa|grep erlang
esl-erlang-18.3-.x86_64
卸载erlang
#rpm -e --nodeps esl-erlang-18.3-.x86_64
RabbitMQ 集群安装过程详解的更多相关文章
- hadoop1.2.1+zk-3.4.5+hbase-0.94.1集群安装过程详解
hadoop1.2.1+zk-3.4.5+hbase-0.94.1集群安装过程详解 一,环境: 1,主机规划: 集群中包括3个节点:hadoop01为Master,其余为Salve,节点之间局域网连接 ...
- redis cluster 集群 安装 配置 详解
redis cluster 集群 安装 配置 详解 张映 发表于 2015-05-01 分类目录: nosql 标签:cluster, redis, 安装, 配置, 集群 Redis 集群是一个提供在 ...
- Nacos集群搭建过程详解
Nacos的单节点,也就是我们最开始使用的standalone模式,配置的数据是默认存储到内嵌的数据库derby中. 如果我们要搭建集群的话,那么肯定是不能用内嵌的数据库,不然数据无法共享.集群搭建的 ...
- k8s集群搭建过程详解
准备工作 安装CentOS7虚拟机 略 安装Docker 略 关闭CentOS7自带的防火墙服务 systemctl disable firewalld systemctl stop firewall ...
- 高可用,多路冗余GFS2集群文件系统搭建详解
高可用,多路冗余GFS2集群文件系统搭建详解 2014.06 标签:GFS2 multipath 集群文件系统 cmirror 实验拓扑图: 实验原理: 实验目的:通过RHCS集群套件搭建GFS2集群 ...
- t持久化与集群部署开发详解
Quartz.net持久化与集群部署开发详解 序言 我前边有几篇文章有介绍过quartz的基本使用语法与类库.但是他的执行计划都是被写在本地的xml文件中.无法做集群部署,我让它看起来脆弱不堪,那是我 ...
- 深入浅出—Redis集群的相关详解
前言: 这篇文章主要介绍了Redis集群的相关,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值. 注意!要求使用的都是redis3.0以上的版本,因为3.0以上增加了red ...
- RabbitMQ集群安装配置+HAproxy+Keepalived高可用
RabbitMQ集群安装配置+HAproxy+Keepalived高可用 转自:https://www.linuxidc.com/Linux/2016-10/136492.htm rabbitmq 集 ...
- 个人用户永久免费,可自动升级版Excel插件,使用VSTO开发,Excel催化剂安装过程详解及安装失败解决方法
因Excel催化剂用了VSTO的开发技术,并且为了最好的用户体验,用了Clickonce的布署方式(无需人工干预自动更新,让用户使用如浏览器访问网站一般,永远是最新的内容和功能).对安装过程有一定的难 ...
随机推荐
- excel基本
1,换行:control+option(alt)+enter
- BZOJ 1061: [Noi2008]志愿者招募
1061: [Noi2008]志愿者招募 Time Limit: 20 Sec Memory Limit: 162 MBSubmit: 4064 Solved: 2476[Submit][Stat ...
- [LeetCode] Roman to Integer 罗马数字转化成整数
Given a roman numeral, convert it to an integer. Input is guaranteed to be within the range from 1 t ...
- Mysql查询——学习阶段
1.开篇 搞开发的都知道,当数据量很大的时候,我们的代码逻辑的简单性就显得十分重要,否则处理起来就需要花费相当多的时间.另外还有一个地方需要注意的是我们写的sql语句. 一个拥有多年开发的资深开发者可 ...
- 编译自己的Ubuntu内核
很多时候我们在使用Ubuntu的时候,想修改一下内核配置,然后编译,安装到Ubuntu中.这也是进行Ubuntu内核开发的前提. 获取当前Ubuntu对应代码 有很多方法可以获得Ubuntu内核代码, ...
- c#常用方法
创建目录 Directory.CreateDirectory(Application.StartupPath+"\\test");
- PHP SPL(PHP 标准库)
一.什么是SPL? SPL是用于解决典型问题(standard problems)的一组接口与类的集合.(出自:http://php.net/manual/zh/intro.spl.php) SPL, ...
- Scala中None, Nil, Nothing的区别
Nil是一个空的List None是一个object,是Option的子类型 List[Nothing]
- iOS-绘图
0 CGContextRef context = UIGraphicsGetCurrentCont ext(); 设置上下文 1 CGContextMoveToPoint 开始画线 2 CGCon ...
- svn服务器地址变换以后,mac下的处理方法
svn服务器地址变换之后,mac下的处理方法 svn服务器地址变换之后,mac下的处理方法 1.进入终端,进入项目所在的文件夹下: cd 项目位置/ 2.查看svn信息 svn info 3.输出结果 ...