前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >linux 安装RabbitMQ

linux 安装RabbitMQ

作者头像
周小董
发布2019-09-19 10:26:43
1.4K0
发布2019-09-19 10:26:43
举报
文章被收录于专栏:python前行者python前行者

版权声明:本文为博主原创文章,遵循 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

展示以下内容说明生效

image
image

安装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
image
image
  • 启动服务后台运行
代码语言:javascript
复制
./rabbitmq-server -detached
image
image
代码语言: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 ".*" ".*" ".*"
image.png
image.png

用户权限指的是用户对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
image.png
image.png

浏览器测试

image.png
image.png

关闭服务

代码语言:javascript
复制
./rabbitmqctl stop
or
service rabbitmq-server stop
image.png
image.png
代码语言: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

本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2019年09月18日,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 安装Erlang
  • 安装rabbitmq
    • 添加用户
      • 删除一个用户
        • 修改用户的密码
          • 设置用户角色
            • 查看用户
              • 设置用户权限
                • 添加虚拟机
                • 这一部分暂时不需要
                  • 配置RabbitMQ
                    • 开启用户远程访问
                    领券
                    问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档