1. 概述
AMQP,即 Advanced Message Queuing Protocol(高级消息队列协议),是一个网络协议,是应用层协议的一个开放标准,为面向消息的中间件设计。基于此协议的客户端与消息中间件可传递消息,并不受客户端/中间件不同产品,不同的开发语言等条件的限制。2006年,AMQP 规范发布。类比HTTP。
AMQP这个过程就是:由生产者发布消息到交换机,交换机再通过路由规则将消息发送到不同的队列中去存储,然后消费者从队列中监听拿走对应的消息来消费。
2007年,Rabbit 技术公司基于 AMQP 标准开发的 RabbitMQ 1.0 发布。RabbitMQ 采用 Erlang 语言开发。Erlang 语言由 Ericson 设计,专门为开发高并发和分布式系统的一种语言,在电信领域使用广泛。
Rabbitmq架构图
RabbitMQ概念:
Broker:接收和分发消息的应用,RabbitMQ Server就是 Message Broker
Virtual host:出于多租户和安全因素设计的,把 AMQP 的基本组件划分到一个虚拟的分组中,类似于网络中的 namespace 概念。当多个不同的用户使用同一个 RabbitMQ server 提供的服务时,可以划分出多个vhost,每个用户在自己的 vhost 创建 exchange/queue 等
Connection:publisher/consumer 和 broker 之间的 TCP 连接
Channel:如果每一次访问 RabbitMQ 都建立一个 Connection,在消息量大的时候建立TCP Connection的开销将是巨大的,效率也较低。Channel 是在 connection 内部建立的逻辑连接,如果应用程序支持多线程,通常每个thread创建单独的 channel 进行通讯,AMQP method 包含了channel id 帮助客户端和message broker 识别 channel,所以 channel 之间是完全隔离的。Channel 作为轻量级的 Connection 极大减少了操作系统建立 TCP connection 的开销
Exchange:message 到达 broker 的第一站,根据分发规则,匹配查询表中的 routing key,分发消息到queue 中去。常用的类型有:direct (point-to-point), topic (publish-subscribe) and fanout (multicast)
Queue:消息最终被送到这里等待 consumer 取走Binding:exchange 和 queue 之间的虚拟连接,binding 中可以包含routing key。Binding 信息被保存到 exchange 中的查询表中,用于 message 的分发依据
6 种工作模式:
- 简单模式
- work queues
- Publish/Subscribe 发布与订阅模式
- Routing路由模式
- Topics 主题模式
- RPC 远程调用模式(远程调用,不太算 MQ;暂不作介绍)
官网对应模式介绍:https://www.rabbitmq.com/getstarted.html
2. 下载安装资源
[root@localhost software]# mkdir rabbitmq
[root@localhost software]# cd rabbitmq/
[root@localhost rabbitmq]# wget --content-disposition https://github.com/rabbitmq/erlang-rpm/releases/download/v23.3.4.10/erlang-23.3.4.10-1.el7.x86_64.rpm
[root@localhost rabbitmq]# wget --content-disposition https://github.com/rabbitmq/rabbitmq-server/releases/download/v3.9.16/rabbitmq-server-3.9.16-1.el7.noarch.rpm
[root@localhost rabbitmq]# wget --content-disposition http://www.rpmfind.net/linux/centos/7.9.2009/os/x86_64/Packages/socat-1.7.3.2-2.el7.x86_64.rpm
[root@localhost rabbitmq]# wget --content-disposition https://github.com/rabbitmq/rabbitmq-delayed-message-exchange/releases/tag/3.9.0/rabbitmq_delayed_message_exchange-3.9.0.ez
[root@localhost rabbitmq]# ls -lh
total 34M
-rw-r--r-- 1 root root 20M Dec 22 2021 erlang-23.3.4.10-1.el7.x86_64.rpm
-rw-r--r-- 1 root root 158K Mar 27 09:39 rabbitmq_delayed_message_exchange-3.9.0.ez
-rw-r--r-- 1 root root 15M Apr 27 2022 rabbitmq-server-3.9.16-1.el7.noarch.rpm
-rw-r--r-- 1 root root 290K Aug 10 2017 socat-1.7.3.2-2.el7.x86_64.rpm
3. 检查与卸载
#卸载erlang
[root@localhost rabbitmq]# yum list | grep erlang
[root@localhost rabbitmq]# find / -name erlang
/usr/lib64/erlang
[root@localhost rabbitmq]# rm -rf /usr/lib64/erlang
[root@localhost rabbitmq]# yum -y remove erlang-*
[root@localhost rabbitmq]# yum remove erlang.x86_64
#卸载rabbitmq
[root@localhost rabbitmq]# yum list | grep rabbitmq
[root@localhost rabbitmq]# yum -y remove rabbitmq-server.noarch
[root@localhost rabbitmq]# whereis rabbitmq
[root@localhost rabbitmq]# rm -rf /usr/lib/rabbitmq
[root@localhost rabbitmq]# rm -rf /etc/rabbitmq
[root@localhost rabbitmq]# find / -name rabbitmq
[root@localhost rabbitmq]# rm -rf /var/lib/rabbitmq
[root@localhost rabbitmq]# rm -rf /var/log/rabbitmq
[root@localhost rabbitmq]# rm -rf /run/rabbitmq
[root@localhost rabbitmq]# rm -rf /etc/selinux/targeted/active/modules/100/rabbitmq
[root@localhost rabbitmq]# rm -rf /etc/selinux/targeted/tmp/modules/100/rabbitmq
#安装编译环境
[root@localhost rabbitmq]# yum -y install build-essential openssl openssl-devel unixODBC unixODBC-devel make gcc gcc-c++ kernel-devel m4 ncurses-devel tk tc xz
#安装erlang
[root@localhost rabbitmq]# rpm -ivh erlang-23.3.4.10-1.el7.x86_64.rpm
[root@localhost rabbitmq]# erl -version
Erlang (SMP,ASYNC_THREADS,HIPE) (BEAM) emulator version 11.2.2.9
#安装socat
[root@localhost rabbitmq]# rpm -ivh socat-1.7.3.2-2.el7.x86_64.rpm
#安装rabbitmq
[root@localhost rabbitmq]# rpm -ivh rabbitmq-server-3.9.16-1.el7.noarch.rpm
[root@localhost rabbitmq]# rpm -qa | grep rabbitmq
#安装rabbitmq_delayed延时队列插件
[root@localhost rabbitmq]# cp rabbitmq_delayed_message_exchange-3.9.0.ez /usr/lib/rabbitmq/lib/rabbitmq_server-3.9.16/plugins
[root@localhost rabbitmq]# cd /usr/lib/rabbitmq/lib/rabbitmq_server-3.9.16/plugins
[root@localhost plugins]# rabbitmq-plugins enable rabbitmq_delayed_message_exchange
#rabbitmq服务[启动|停止|重启|状态|自启]
[root@localhost plugins]# vi /etc/hosts
添加 127.0.0.1 mail
[root@localhost plugins]# systemctl start rabbitmq-server
[root@localhost plugins]# journalctl -u rabbitmq-server
[root@localhost plugins]# systemctl [start|stop|restart|status|enable] rabbitmq-server
#创建相关账户
[root@localhost plugins]# rabbitmqctl add_user ubox *********
[root@localhost plugins]# rabbitmqctl set_user_tags ubox administrator
[root@localhost plugins]# rabbitmqctl set_permissions -p "/" ubox ".*" ".*" ".*"
[root@localhost plugins]# rabbitmqctl add_vhost ubox
[root@localhost plugins]# rabbitmqctl list_vhosts
[root@localhost plugins]# rabbitmqctl list_users
#其他命令行
#添加用户
rabbitmqctl add_user 用户名 密码
#删除用户
rabbitmqctl delete_user 用户名
#修改用户密码
rabbitmqctl change_password 用户名 新密码
#查看用户列表
rabbitmqctl list_users
#分配用户角色
rabbitmqctl set_user_tags ubox administrator
#添加虚拟机
rabbitmqctl add_vhost xxx
#删除虚拟机
rabbitmqctl delete_vhost xxx
#查看虚拟机列表
#rabbitmqctl list_vhosts
#分配用户具体权限
rabbitmqctl set_permissions -p / 用户名 ".*" ".*" ".*"
#清除用户权限
rabbitmqctl clear_permissions [-p VHostPath] User
#先查看所有开放的端口号
sudo firewall-cmd --zone=public --list-ports
#开放15672和5672端口
iptables -I INPUT -p tcp --dport 5672 -j ACCEPT
iptables -I INPUT -p tcp --dport 15672 -j ACCEPT
#重载使上述命令生效
firewall-cmd --reload