xdm 我的文章 链接如下,不能在微信公众号发下面这一篇,原因是这篇文章被别人引用,发到了微信公众号上面:
我们一起来学RabbitMQ 二:RabbiMQ 的 6 种模式的基本应
https://www.rabbitmq.com/install-windows.html
搜索关键字 Download
https://www.erlang.org/downloads
点击上述下载的 otp_win64_24.0.exe
一直 next 即可,记住自己的安装路径,使用默认的即可,若自定义,最好全路径都是英文
image-
如上图效果,即为安装配置 erlang 环境成功
C:\Program Files\RabbitMQ Server\rabbitmq_server-3.8.19\sbin
rabbitmq-plugins enable rabbitmq_management
会看到上述效果,三个插件被启动了
账号:guest
密码:guest
net start RabbitMQ 启动
net stop RabbitMQ 停止
rabbitmqctl status 查看状态
咱们再来看看linux 中RabbitMQ 如何安装和使用
RabbitMQ使用erlang语言写的,所以在安装RabbitMQ前,我们需要安装erlang,erlang又需要安装 python 和 simplejson
wget https://www.python.org/ftp/python/3.5.2/Python-3.5.2.tar.xz
tar xvf Python-3.5.2.tar.xz
cd Python-3.5.2
./configure
make && make install
sudo apt-get install python-simplejson -y
sudo apt-get install build-essential -y
sudo apt-get install libncurses5-dev -y
sudo apt-get install libssl-dev -y
sudo apt-get install m4 -y
sudo apt-get install unixodbc unixodbc-dev -y
sudo apt-get install freeglut3-dev libwxgtk2.8-dev -y
sudo apt-get install xsltproc -y
sudo apt-get install fop -y
sudo apt-get install tk8 -y
sudo apt-get install erlang -y
sudo apt-get update
sudo apt-get install rabbitmq-server
查看 RabbitMQ 状态
# systemctl status rabbitmq-server
● rabbitmq-server.service - RabbitMQ Messaging Server
Loaded: loaded (/lib/systemd/system/rabbitmq-server.service; enabled; vendor preset: enabled)
Active: active (running) since Fri 2021-07-23 14:51:31 CST; 7min ago
Main PID: 426 (beam.smp)
Status: "Initialized"
Tasks: 85 (limit: 2338)
CGroup: /system.slice/rabbitmq-server.service
├─ 413 /bin/sh /usr/sbin/rabbitmq-server
├─ 426 /usr/lib/erlang/erts-9.2/bin/beam.smp -W w -A 64 -P 1048576 -t 5000000 -stbt db -zdbbl 32000 -K true -- -root /usr/lib/erlang -progname erl -- -home /var/lib/rabbitmq -- -pa
├─ 604 /usr/lib/erlang/erts-9.2/bin/epmd -daemon
├─ 904 erl_child_setup 65536
├─1000 inet_gethost 4
└─1001 inet_gethost 4
RabbitMQ management 插件可以提供Web管理界面用来管理虚拟主机、用户等,也可以用来管理队列、交换机、绑定关系、策略、参数等
还可以用来监控RabbitMQ服务的状态及一些数据统计类信息 ,有兴趣的可以感受一下
每一个 RabbitMQ 服务器都能创建虚拟的消息服务器,称为虚拟主机( Virtual Host ),简称vhost。
每一个本质上都是一个独立的小型RabbitMQ服务器,拥有自己独立的队列、交换机及绑定关系等,并且它拥有自己独立的权限。
Virtual Host相互之间是绝对隔离的,无法将vhost1中的交换机与vhost2中的队列进行绑定,这样既保证了安全性,又可以确保可移植性
安装好 RabbitMQ 后,会有一个默认的 vhost 为 /
rabbitmqctl add_vhost xxx
命令创建一个新的 vhostroot@xxx:/# rabbitmqctl add_vhost testvhost
Creating vhost "testvhost"
rabbitmqctl delete_vhost xxx
root@xx:/# rabbitmqctl delete_vhost testvhost
Deleting vhost "testvhost"
注意
删除一个 vhost 同时也会删除其下所有的队列、交换机、绑定关系、用户权限、参数和策略等信息
当创建一个用户时,用户通常会被指派给至少一个 vhost,并且只能访问被指派的 vhost 内的队列、交换机和绑定关系等。
因此,RabbitMQ 中的授权是指在vhost级别对用户而言的权限授予
相关的授权命令为:
rabbitmqctl set_permissions [-p vhost] {user} {conf} {write} {read}
/
root@xxx:/# rabbitmqctl set_permissions -p testvhost root ".*" ".*" ".*"
Setting permissions for user "root" in vhost "testvhost"
用来显示虚拟主机上的权限:rabbitmqctl list_permissions [-p vhost]
root@xxx:/# rabbitmqctl list_permissions -p testvhost
Listing permissions in vhost "testvhost"
root .* .* .*
用来显示用户的权限:rabbitmqctl list_user_permissions {username}
root@983cebfa9073:/# rabbitmqctl list_user_permissions root
Listing permissions for user "root"
testvhost .* .* .*
/ .* .* .*
在 RabbitMQ 中,用户是访问控制的基本单位
单个用户可以跨越多个 vhost 进行授权
针对一至多个 vhost ,用户可以被赋予不同级别的访问权限,并使用标准的用户名和密码来认证用户
rabbitmqctl add_user {username} {password}
root@xx:/# rabbitmqctl add_user root 123456
Creating user "root"
rabbitmqctl change_password {username} {password}
root@xx:/# rabbitmqctl change_password root test001
Changing password for user "root"
用户的角色分为 5种 类型
角色 | 权限 |
---|---|
administrator | 最高权限,包含monitoring的所有权限,并且可以管理用户、虚拟主机、权限、策略、参数等 |
monitoring | 包含management的所有权限,并且可以看到所有连接、信道及节点相关信息 |
policymaker | 包含management的所有权限,并且可以管理策略和参数 |
management | 可以访问Web管理界面 |
none | 默认权限,无任何角色,新建的用户默认为none |
rabbitmqctl set_user_tags {username} {tag …}
root@xx:/# rabbitmqctl set_user_tags root administrator
Setting tags for user "root" to [administrator]
rabbitmqctl clear_password {username}
root@xx:/# rabbitmqctl clear_password root
Clearing password for user "root"
rabbitmqctl authenticate_user {username} {password}
root@xx:/# rabbitmqctl authenticate_user root test001
Authenticating user "root"
Success
root@xx:/# rabbitmqctl authenticate_user root 123456
Authenticating user "root"
Error: failed to authenticate user "root"
rabbitmqctl list_users , 每一个用户后面紧跟用户的角色
root@xx:/# rabbitmqctl list_users
Listing users
root [administrator]
rabbitmqctl delete_use {username}
root@xx:/# rabbitmqctl delete_user root
Deleting user "root"
访问Web管理界面
http://localhost:15672/
http://IP:15672/
Protocol | Bound to | Port |
---|---|---|
amqp | :: | 5672 |
clustering | :: | 25672 |
http | :: | 15672 |
使用 amqp 协议的时候
访问 web 管理页面需要的端口
集群的时候,多个 rabbitmq-server 相互通信的时候使用
参考资料:
RabbitMQ Tutorials
朋友们,你的支持和鼓励,是我坚持分享,提高质量的动力
好了,本次就到这里
技术是开放的,我们的心态,更应是开放的。拥抱变化,向阳而生,努力向前行。
我是小魔童哪吒,欢迎点赞关注收藏,下次见~