前言:
RabbitMQ是一个由Erlang开发的AMQP(AdvancedMessage Queue )的开源实现,用于在分布式系统中存储转发消息。
AMQP,即Advanced Message Queuing Protocol,一个提供统一消息服务的应用层标准高级消息队列协议,是应用层协议的一个开放标准,为面向消息的中间件设计。基于此协议的客户端与消息中间件可传递消息,并不受客户端/中间件不同产品,不同的开发语言等条件的限制。它主要特征是面向消息、队列、路由(包括点对点和发布/订阅)、可靠性、安全。
简单的介绍一下AMQP的协议栈,AMQP协议本身包含三层,如下:
Model Layer,位于协议最高层,主要定义了一些供客户端调用的命令,客户端可以通过这些命令实现自己的业务逻辑,例如,客户端可以通过queue declare声明一个队列,利用consume命令获取队列的消息。
Session Layer,主要负责将客户端命令发送给服务器,在将服务器端的应答返回给客户端,主要为客户端与服务器之间通信提供可靠性、同步机制和错误处理。
Transport Layer,主要传输二进制数据流,提供帧的处理、信道复用、错误检测和数据表示。
这种分层架构,可替换各层实现而不影响与其它层的交互。AMQP定义了合适的服务器端域模型,用于规范服务器的行为(AMQP服务器端可称为消息代理中间人)。在这里Model层决定这些基本域模型所产生的行为,这种行为在AMQP中用command表示。Session层定义客户端与broker之间的通信(通信双方可互称做搭档),为command的可靠传输提供保障。Transport层专注于数据传送,并与Session保持交互,接受上层的数据,组装成二进制流,传送到接受者后再解析数据,交付给Session层。Session层需要Transport层完成网络异常情况的汇报,顺序传送command等工作。
AMQP中的一些概念。
Broker(Server):接受客户端连接,实现AMQP消息队列和路由功能的进程,作为消息提供者和消息消费者之间的中间人。
Virtual Host:其实是一个虚拟概念,类似于权限控制组,一个Virtual Host里面可以有若干个Exchange和Queue,但是权限控制的最小粒度是Virtual Host。
Exchange:接受生产者发送的消息,并根据Binding规则将消息路由给服务器中的队列。ExchangeType决定了Exchange路由消息的行为,例如,在RabbitMQ中,ExchangeType有direct、Fanout和Topic三种,不同类型的Exchange路由的行为是不一样的。
Message Queue:消息队列,用于存储还未被消费者消费的消息。
Message:由Header和Body组成,Header是由生产者添加的各种属性的集合,包括Message是否被持久化、由哪个Message Queue接受、优先级是多少等。而Body是真正需要传输的APP数据。
Binding:Binding联系了Exchange与MessageQueue。Exchange在与多个MessageQueue发生Binding后会生成一张路由表,路由表中存储着Message Queue所需消息的限制条件即Binding Key。当Exchange收到Message时会解析其Header得到Routing Key,Exchange根据Routing Key与ExchangeType将Message路由到MessageQueue。Binding Key由Consumer在Binding Exchange与MessageQueue时指定,而Routing Key由Producer发送Message时指定,两者的匹配方式由ExchangeType决定。
Connection:连接,对于RabbitMQ而言,其实就是一个位于客户端和Broker之间的TCP连接。
Channel:信道,仅仅创建了客户端到Broker之间的连接后,客户端还是不能发送消息的。AMQP协议规定只有通过Channel才能执行AMQP的命令,所以需要为每一个Connection创建Channel。一个Connection可以包含多个Channel。之所以需要Channel,是因为TCP连接的建立和释放都是十分昂贵的,如果一个客户端每一个线程都需要与Broker交互,如果每一个线程都建立一个TCP连接,暂且不考虑TCP连接是否浪费,就算操作系统也无法承受每秒建立如此多的TCP连接。RabbitMQ建议客户端线程之间不要共用Channel,至少要保证共用Channel的线程发送消息必须是串行的,但是建议尽量共用Connection。
Command:AMQP的命令,客户端通过Command完成与AMQP服务器的交互来实现自身的逻辑
一、Rabbitmq的启动运行(windows10系统)
2019-08-11 09:23:38.475 [info] <0.33.0> Application lager started on node 'rabbit@DESKTOP-MFL4IGI'
2019-08-11 09:23:38.491 [info] <0.5.0> Log file opened with Lager
2019-08-11 09:23:40.083 [info] <0.33.0> Application xmerl started on node 'rabbit@DESKTOP-MFL4IGI'
2019-08-11 09:23:40.208 [info] <0.33.0> Application inets started on node 'rabbit@DESKTOP-MFL4IGI'
2019-08-11 09:23:40.208 [info] <0.33.0> Application recon started on node 'rabbit@DESKTOP-MFL4IGI'
2019-08-11 09:23:40.208 [info] <0.33.0> Application jsx started on node 'rabbit@DESKTOP-MFL4IGI'
2019-08-11 09:23:40.223 [info] <0.33.0> Application mnesia started on node 'rabbit@DESKTOP-MFL4IGI'
2019-08-11 09:23:40.286 [info] <0.33.0> Application os_mon started on node 'rabbit@DESKTOP-MFL4IGI'
2019-08-11 09:23:40.286 [info] <0.33.0> Application asn1 started on node 'rabbit@DESKTOP-MFL4IGI'
2019-08-11 09:23:40.286 [info] <0.33.0> Application crypto started on node 'rabbit@DESKTOP-MFL4IGI'
2019-08-11 09:23:40.286 [info] <0.33.0> Application cowlib started on node 'rabbit@DESKTOP-MFL4IGI'
2019-08-11 09:23:40.286 [info] <0.33.0> Application public_key started on node 'rabbit@DESKTOP-MFL4IGI'
2019-08-11 09:23:40.364 [info] <0.33.0> Application ssl started on node 'rabbit@DESKTOP-MFL4IGI'
2019-08-11 09:23:40.379 [info] <0.33.0> Application ranch started on node 'rabbit@DESKTOP-MFL4IGI'
2019-08-11 09:23:40.379 [info] <0.33.0> Application cowboy started on node 'rabbit@DESKTOP-MFL4IGI'
2019-08-11 09:23:40.379 [info] <0.33.0> Application ranch_proxy_protocol started on node 'rabbit@DESKTOP-MFL4IGI'
2019-08-11 09:23:40.379 [info] <0.33.0> Application rabbit_common started on node 'rabbit@DESKTOP-MFL4IGI'
2019-08-11 09:23:40.474 [info] <0.259.0>
Starting RabbitMQ 3.7.4 on Erlang 20.3
Copyright (C) 2007-2018 Pivotal Software, Inc.
Licensed under the MPL. See http://www.rabbitmq.com/
2019-08-11 09:23:40.474 [info] <0.259.0>
node : rabbit@DESKTOP-MFL4IGI
home dir : C:\WINDOWS\system32\config\systemprofile
config file(s) : e:/RabbitMQ/rabbitmq_server-3.7.4/etc/rabbitmq.config
cookie hash : 8iOMTukzSRyT0kv4kWjyQQ==
log(s) : C:/Users/zht/AppData/Roaming/RabbitMQ/log/RABBIT~1.LOG
: C:/Users/zht/AppData/Roaming/RabbitMQ/log/rabbit@DESKTOP-MFL4IGI_upgrade.log
database dir : c:/Users/zht/AppData/Roaming/RabbitMQ/db/RABBIT~1
2019-08-11 09:23:42.692 [info] <0.267