RabbitMQ介绍
成都创新互联服务项目包括乐安网站建设、乐安网站制作、乐安网页制作以及乐安网络营销策划等。多年来,我们专注于互联网行业,利用自身积累的技术优势、行业经验、深度合作伙伴关系等,向广大中小型企业、政府机构等提供互联网行业的解决方案,乐安网站推广取得了明显的社会效益与经济效益。目前,我们服务的客户以成都为中心已经辐射到乐安省份的部分城市,未来相信会继续扩大服务区域并继续获得客户的支持与信任!
MQ全称为Message Queue, 消息队列(MQ)是一种应用程序对应用程序的通信方法。应用程序通过读写出入队列的消息(针对应用程序的数据)来通信,而无需专用连接来链接它们。消息传递指的是程序之间通过在消息中发送数据进行通信,而不是通过直接调用彼此来通信,直接调用通常是用于诸如远程过程调用的技术。排队指的是应用程序通过 队列来通信。队列的使用除去了接收和发送应用程序同时执行的要求。
RabbitMQ是流行的开源消息队列系统,用erlang语言开发。RabbitMQ是AMQP(高级消息队列协议)的标准实现。
RabbitMQ原理图示
Exchange四种匹配模式
fanout:将生产者发送的信息推送到所有与他绑定的Queue;
direct:精准匹配,当routing key=binding key时,将信息发送到对应的Queue;
topic:模糊匹配,当满足部分规则时,将信息发送到对应的Queue;
headers:不依赖routing key,binding key匹配规则,依据消息内容headers属性匹配。
关键概念介绍
Broker:简单来说就是消息队列服务器实体。
Exchange:消息交换机,它指定消息按什么规则,路由到哪个队列。
Queue:消息队列载体,每个消息都会被投入到一个或多个队列。
Binding:绑定,它的作用就是把exchange和queue按照路由规则绑定起来。
Routing Key:路由关键字,exchange根据这个关键字进行消息投递。
vhost:虚拟主机,一个broker里可以开设多个vhost,用作不同用户的权限分离。
producer:消息生产者,就是投递消息的程序。
consumer:消息消费者,就是接受消息的程序。
channel:消息通道,在客户端的每个连接里,可建立多个channel,每个channel代表一个会话任务。
消息队列的使用过程大概如下:
(1)客户端连接到消息队列服务器,打开一个channel。
(2)客户端声明一个exchange,并设置相关属性。
(3)客户端声明一个queue,并设置相关属性。
(4)客户端使用routing key,在exchange和queue之间建立好绑定关系。
(5)客户端投递消息到exchange。
RabbitMQ实验搭建
配置信息:
配置步骤:
一、更改主机名(防止启动服务时出现故障):
mq01/mq02/mq03:
vim /etc/hostname
mq01.localdomain
vim /etc/hosts
192.168.218.156 mq01
192.168.218.145 mq02
192.168.218.139 mq03
二、构建独立的服务器
mq01/mq02/mq03:
systemctl stop firewalld.service
setenforce 0
yum install epel-release -y
yum install rabbitmq-server -y
ln -s /usr/lib/rabbitmq/bin/* /usr/bin/
rabbitmq-plugins list //查看插件安装情况
rabbitmq-plugins enable rabbitmq_management //启用rabbitmq_management管理
systemctl start rabbitmq-server.service //开启服务
rabbitmqctl cluster_status //检查集群状态(主机名未解析会报error)
Cluster status of node rabbit@mq01 ...
[{nodes,[{disc,[rabbit@mq01]}]},
{running_nodes,[rabbit@mq01]},
{cluster_name,<<"rabbit@mq01">>},
{partitions,[]}]
...done.
三、构建RabbitMQ群集
mq01/mq02/mq03:
systemctl stop rabbitmq-server.service
[root@mq01 ~]# cat /var/lib/rabbitmq/.erlang.cookie
FDFUVYLHUIERZZNQUKPM //同步三台cookie相同
systemctl start rabbitmq-server.service
内存节点 mq02/03
rabbitmqctl stop_app
rabbitmqctl join_cluster --ram rabbit@mq01 //以内存节点形式存在
rabbitmqctl start_app
rabbitmqctl cluster_status //检查集群状态
Cluster status of node rabbit@mq01 ...
[{nodes,[{disc,[rabbit@mq01]},{ram,[rabbit@mq03,rabbit@mq02]}]},
{running_nodes,[rabbit@mq03,rabbit@mq02,rabbit@mq01]},
{cluster_name,<<"rabbit@mq01">>},
{partitions,[]}]
...done.
http://192.168.218.156:15672/ //登录磁盘节点服务器 //默认用户名:guest 密码:guest