87447007 2020-05-16
来自:https://www.cnblogs.com/skychenjiajun/p/8930147.html
一、通过yum命令在线安装RabbitMQ
yum在线安装,简单、快捷、自动安装相关依赖包。
1.安装Erlang环境(RabbitMQ由Erlang语言开发)
1.1)下载rpm安装包
官方地址:http://www.erlang.org/downloads
wget --content-disposition https://packagecloud.io/rabbitmq/erlang/packages/el/7/erlang-20.3-1.el7.centos.x86_64.rpm/download.rpm
1.2)安装Erlang
yum install erlang-20.3-1.el7.centos.x86_64.rpm
1.3)检查Erlang是否安装成功
[ ~]# erl -version
Erlang (SMP,ASYNC_THREADS,HIPE) (BEAM) emulator version 9.3
2.安装RabbitMQ
2.1)下载rpm安装包
官方地址:http://www.rabbitmq.com/download.html
wget https://dl.bintray.com/rabbitmq/all/rabbitmq-server/3.7.4/rabbitmq-server-3.7.4-1.el7.noarch.rpm
Error: Package: rabbitmq-server-3.6.1-1.noarch (/rabbitmq-server-3.6.1-1.noarch)
Requires: erlang >= R16B-3
You could try using --skip-broken to work around the problem
You could try running: rpm -Va --nofiles --nodigest
这是由于erlang的版本问题,其实是没有影响的,你可以使用下面的命令进行安装:
#rpm -ivh --nodeps rabbitmq-server-3.6.1-1.noarch.rpm
问题现象
Warning: PID file not written; -detached was passed. ERROR: epmd error for host prd-can3-0-mq01: timeout (timed out)
问题解决
经过一番检查,其实RabbitMQ报这个错的原因是无法在/etc/hosts中正确识别主机名,因此只需修改该文件即可
127.0.0.1 prd-can3-0-mq01 localhost localhost.localdomain localhost4 localhost4.localdomain4 ::1 localhost localhost.localdomain localhost6 localhost6.localdomain6
2.2)安装RabbitMQ
yum install -y rabbitmq-server-3.7.4-1.el7.noarch.rpm
2.3)检查RabbitMQ是否安装成功
[ ~]# rabbitmqctl status
Status of node …
[{pid,14618},
{running_applications,
[{rabbitmq_management,“RabbitMQ Management Console”,“3.7.4”},
{rabbitmq_management_agent,“RabbitMQ Management Agent”,“3.7.4”},
{amqp_client,“RabbitMQ AMQP Client”,“3.7.4”},
{rabbitmq_web_dispatch,“RabbitMQ Web Dispatcher”,“3.7.4”},
{cowboy,“Small, fast, modern HTTP server.”,“2.2.2”},
{cowlib,“Support library for manipulating Web protocols.”,“2.1.0”},
{rabbit,“RabbitMQ”,“3.7.4”},
{rabbit_common,
“Modules shared by rabbitmq-server and rabbitmq-erlang-client”,
“3.7.4”},
…
3.关于服务
启动服务:systemctl start rabbitmq-server.service /rabbitmq-server start & /rabbitmq-server start_app
停止服务:systemctl stop rabbitmq-server.service / rabbitmq-server stop_app
设置开机启动:systemctl enable rabbitmq-server.service
停止开机启动:systemctl disable rabbitmq-server.service
重新启动服务:systemctl restart rabbitmq-server.service
查看服务当前状态:systemctl status rabbitmq-server.service/rabbitmqctl status
查看所有已启动服务:systemctl list-units --type=service
4.用户管理
4.1)查看用户列表
[ ~]# rabbitmqctl list_users
Listing users …
guest [administrator]
[ ~]#
4.2)添加用户
rabbitmqctl add_user 用户名 密码
[ ~]# rabbitmqctl add_user admin 123456
Adding user “admin” …
[ ~]#
4.3)删除用户
rabbitmqctl delete_user 用户名
[ ~]# rabbitmqctl delete_user admin
Deleting user “admin” …
[ ~]#
4.4)修改用户密码
rabbitmqctl change_password 用户名 新密码
[ ~]# rabbitmqctl change_password admin 666666
Changing password for user “admin” …
[ ~]#
5.角色管理
5.1)角色说明
复制代码
none(普通用户)
没有控制台操作权限。
management(普通管理员)
可以查看当前用户的queues, exchanges和bindings。
可以查看和关闭当前用户的channels和connections。
可以查看当前用户的virtual hosts的统计信息。
policymaker(策略管理员)
具有management权限及查看、创建和删除当前用户的policies和parameters。
monitoring(监控管理员)
具有management权限
查看所有virtual hosts及全局的统计信息
查看所有用户的connections和channels
查看所有节点数据,如clustering和memory使用情况
administrator(超级管理员)
具有policymaker、monitoring权限
查看、创建、删除所有virtual hosts
查看、创建、删除所有users
查看、创建、删除所有permissions
可以关闭所有用户的connections
复制代码
5.2)查看用户角色
rabbitmqctl list_users 用户名
[ ~]# rabbitmqctl list_users
Listing users …
admin [administrator]
guest [administrator]
[ ~]#
5.3)设置用户角色
rabbitmqctl set_user_tags admin 角色名称(支持同时设置多个角色)
[ ~]# rabbitmqctl set_user_tags admin administrator
Setting tags for user “admin” to [administrator] …
[ ~]#
6.权限管理
用户权限是指用户对exchange,queue的操作权限,包括配置权限,读写权限。配置权限会影响到exchange,queue的声明和删除。读写权限会影响到queue的读写消息、exchange发送消息以及queue和exchange的绑定操作。
6.1)查看用户权限
rabbitmqctl list_user_permissions 用户名
[ ~]# rabbitmqctl list_user_permissions guest
Listing permissions for user “guest” …
/ .* .* .*
[ ~]#
6.2)设置用户权限
rabbitmqctl set_permissions -p 虚拟主机名称 用户名
[ ~]# rabbitmqctl set_permissions -p / admin ‘.’ ‘.’ ‘.*’
Setting permissions for user “admin” in vhost “/” …
[ ~]#
7.虚拟主机管理
为什么需要虚拟主机(vhost)?因为RabbitMQ只能在虚拟主机的粒度上进行权限控制。每个vhost本质上是一个mini版的RabbitMQ服务器,拥有自己的队列、交换器和绑定等。
7.1)查看虚拟主机
[ ~]# rabbitmqctl list_vhosts
Listing vhosts …
/
[ ~]#
7.2)添加虚拟主机
rabbitmqctl add_vhost 虚拟主机名称
[ ~]# rabbitmqctl add_vhost coreSystem
Adding vhost “coreSystem” …
[ ~]#
7.3)删除虚拟主机
rabbitmqctl delete_vhost 虚拟主机名称
[ ~]# rabbitmqctl delete_vhost coreSystem
Deleting vhost “coreSystem” …
[ ~]#
8.web后台管理
8.1)启用后台管理插件
复制代码
[ ~]# rabbitmq-plugins enable rabbitmq_management
The following plugins have been configured:
rabbitmq_management
rabbitmq_management_agent
rabbitmq_web_dispatch
Applying plugin configuration to …
The following plugins have been enabled:
rabbitmq_management
rabbitmq_management_agent
rabbitmq_web_dispatch
started 3 plugins.
[ ~]#
复制代码
8.2)登录
浏览器输入:http://服务器Ip:15672/