版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://blog.csdn.net/xc_zhou/article/details/100994760
RabbitMQ依赖Erlang, 所以需要先安装Erlang。
安装Erlang
- 安装类库
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
- 设置环境变量
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
- 使环境变量生效
source /etc/profile
- 测试erlang是否可用以及变量是否生效
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管理插件
查看插件列表
# ./rabbitmq-plugins list
./rabbitmq-plugins enable rabbitmq_management
- 启动服务后台运行
./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下查找某个文件位置的方法
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