Rabbitmq使用姿势

前言:

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

  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值