linux 安装RabbitMQ

2019-09-19 10:26:43 浏览数 (1)

版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。

本文链接:https://blog.csdn.net/xc_zhou/article/details/100994760

RabbitMQ依赖Erlang, 所以需要先安装Erlang。

安装Erlang

  • 安装类库
代码语言:javascript复制
yum -y install make
yum -y install ncurses-devel
yum -y install openssl-devel
yum -y install unixODBC-devel
yum -y install gcc
yum -y install gcc-c  
yum -y install kernel-devel
yum -y install m4 

准备安装包otp_src_20.3.tar.gz,解压,配置、编译并安装 下载Erlang安装包:http://erlang.org/download/otp_src_20.3.tar.gz

代码语言:javascript复制
mkdir -p /usr/local/erlang
tar -xvf otp_src_20.3.tar.gz
cd otp_src_20.3
# ./configure --prefix=/usr/local/erlang --with-ssl --enable-threads --enable-smp-support --enable-kernel-poll --enable-hipe --without-javac
# make -j8
./configure --prefix=/usr/local/erlang
make
make install
  • 设置环境变量
代码语言:javascript复制
vim /etc/profile
在末尾加入以下内容:
#set erlang environment
export PAHT=$PATH:/usr/local/erlang/bin

or 
export ERLANG_HOME=/usr/local/erlang
export PATH=$ERLANG_HOME/bin:$PATH
  • 使环境变量生效
代码语言:javascript复制
source /etc/profile
  • 测试erlang是否可用以及变量是否生效
代码语言:javascript复制
erl

展示以下内容说明生效

安装rabbitmq

mq依赖

代码语言:javascript复制
yum -y install epel-release 
yum -y install socat

下载地址:https://www.rabbitmq.com/versions.html 本人安装的是3.7.18版本:https://github.com/rabbitmq/rabbitmq-server/releases/download/v3.7.18/rabbitmq-server-generic-unix-3.7.18.tar.xz

代码语言:javascript复制
yum install xz
xz -d rabbitmq-server-generic-unix-3.7.18.tar.xz
tar -xvf rabbitmq-server-generic-unix-3.7.18.tar
cp -r rabbitmq_server-3.7.18 /usr/local/rabbitmq

这种方式无需make

  • 启用WEB管理插件
代码语言:javascript复制
查看插件列表
# ./rabbitmq-plugins list
./rabbitmq-plugins enable rabbitmq_management
  • 启动服务后台运行
代码语言:javascript复制
./rabbitmq-server -detached
代码语言:javascript复制
我们再来查看看一下rabbitmq的默认监听端口5672

查看TCP端口
netstat -tnlp|grep 5672
查看所有8088端口
netstat -ntulp | grep 8088

netstat -napt|grep 5672

最好我们就可以在浏览器上输入http://ip:15672/登录管理界面了
如果管理界面不能访问,先`ping ip`看网络通不通,再看外部访问端口通不通`telnet ip 端口号`

默认使用登录的用户名和密码都是guest

关闭防火墙,否则非本地设备无法访问RabbitMQ服务

CentOS 7.0默认使用的是firewall作为防火墙

查看防火墙状态

代码语言:javascript复制
firewall-cmd --state

停止firewall

代码语言:javascript复制
systemctl stop firewalld.service

禁止firewall开机启动

代码语言:javascript复制
systemctl disable firewalld.service 
添加用户
代码语言:javascript复制
./rabbitmqctl add_user root 123456
删除一个用户
代码语言:javascript复制
rabbitmqctl delete_user Username
修改用户的密码
代码语言:javascript复制
rabbitmqctl change_password Username Newpassword
设置用户角色
代码语言:javascript复制
./rabbitmqctl set_user_tags root administrator

按照个人理解,用户角色可分为五类,超级管理员, 监控者, 策略制定者, 普通管理者以及其他。

(1) 超级管理员(administrator)

可登陆管理控制台(启用management plugin的情况下),可查看所有的信息,并且可以对用户,策略(policy)进行操作。

(2) 监控者(monitoring)

可登陆管理控制台(启用management plugin的情况下),同时可以查看rabbitmq节点的相关信息(进程数,内存使用情况,磁盘使用情况等)

(3) 策略制定者(policymaker)

可登陆管理控制台(启用management plugin的情况下), 同时可以对policy进行管理。但无法查看节点的相关信息(上图红框标识的部分)。

与administrator的对比,administrator能看到这些内容

(4) 普通管理者(management)

仅可登陆管理控制台(启用management plugin的情况下),无法看到节点信息,也无法对策略进行管理。

(5) 其他

无法登陆管理控制台,通常就是普通的生产者和消费者。

了解了这些后,就可以根据需要给不同的用户设置不同的角色,以便按需管理。

设置用户角色的命令为:

代码语言:javascript复制
rabbitmqctl set_user_tags User Tag

User为用户名, Tag为角色名(对应于上面的administrator,monitoring,policymaker,management,或其他自定义名称)。

也可以给同一用户设置多个角色,例如

代码语言:javascript复制
rabbitmqctl set_user_tags hncscwc monitoring policymaker
查看用户
代码语言:javascript复制
./rabbitmqctl list_users
设置用户权限
代码语言:javascript复制
./rabbitmqctl set_permissions -p / root ".*" ".*" ".*"

用户权限指的是用户对exchange,queue的操作权限,包括配置权限,读写权限。配置权限会影响到exchange,queue的声明和删除。读写权限影响到从queue里取消息,向exchange发送消息以及queue和exchange的绑定(bind)操作。

例如: 将queue绑定到某exchange上,需要具有queue的可写权限,以及exchange的可读权限;向exchange发送消息需要具有exchange的可写权限;从queue里取数据需要具有queue的可读权限。详细请参考官方文档中"How permissions work"部分。

相关命令为:

(1) 设置用户权限

代码语言:javascript复制
rabbitmqctl set_permissions -p VHostPath User ConfP WriteP ReadP

(2) 查看(指定hostpath)所有用户的权限信息

代码语言:javascript复制
rabbitmqctl list_permissions [-p VHostPath]

(3) 查看指定用户的权限信息

代码语言:javascript复制
rabbitmqctl list_user_permissions User

(4) 清除用户的权限信息

代码语言:javascript复制
rabbitmqctl clear_permissions [-p VHostPath] User
添加虚拟机
代码语言:javascript复制
添加虚拟机: # ./rabbitmqctl add_vhost vhostname
如:./rabbitmqctl add_vhost admin_vhost
授权用户到虚拟机: # ./rabbitmqctl set_permissions -p vhostname username ".*" ".*" ".*"
如:./rabbitmqctl set_permissions -p admin_vhost admin ".*" ".*" ".*"

查看RabbitMQ运行状态

代码语言:javascript复制
./rabbitmqctl status
or
rabbitmq-server status

浏览器测试

关闭服务

代码语言:javascript复制
./rabbitmqctl stop
or
service rabbitmq-server stop
代码语言:javascript复制
设置开机启动
chkconfig rabbitmq-server on

这一部分暂时不需要

配置RabbitMQ

关于RabbitMQ的配置,可以下载RabbitMQ的配置文件模板:https://raw.githubusercontent.com/rabbitmq/rabbitmq-server/stable/docs/rabbitmq.config.example到/etc/rabbitmq/rabbitmq.config, 然后按照需求更改即可。 关于每个配置项的具体作用,可以参考官方文档:https://www.rabbitmq.com/configure.html。

开启用户远程访问

默认情况下,RabbitMQ的默认的guest用户只允许本机访问, 如果想让guest用户能够远程访问的话,只需要将配置文件中的loopback_users列表置为空即可,如下:

代码语言:javascript复制
{loopback_users, []}

另外关于新添加的用户,直接就可以从远程访问的,如果想让新添加的用户只能本地访问,可以将用户名添加到上面的列表, 如只允许admin用户本机访问。

代码语言:javascript复制
{loopback_users, ["admin"]}

更新配置后,别忘了重启服务哦!

  • 开放端口

端口开放要放在22的下方 vi /etc/sysconfig/iptables 添加:(15672:网页版访问使用, 5672:程序)

代码语言:javascript复制
-A INPUT -m state --state NEW -m tcp -p tcp --dport 15672 -j ACCEPT
-A INPUT -m state --state NEW -m tcp -p tcp --dport 5672 -j ACCEPT
  • linux下查找某个文件位置的方法
代码语言:javascript复制
find / -name file_name

rabbitMQ和对应的erlang版本匹配 :https://www.rabbitmq.com/which-erlang.html

参考:https://blog.csdn.net/vinegar93/article/details/82867937 https://www.cnblogs.com/dreasky/p/9146494.html https://blog.csdn.net/ytangdigl/article/details/79796961 https://blog.csdn.net/qq_34898847/article/details/82899053 https://blog.csdn.net/qq_22075041/article/details/78855708 https://www.rabbitmq.com/versions.html

0 人点赞