rabbitMQ组成部分

rabbitmq有以下组成部分,分别为:

1. Server(broker)
接受客户端连接,实现AMQP消息队列和路由功能的进程

2.虚拟主机virtual host
虚拟主机类似于权限控制组,控制用户访问虚拟主机的权限。
权限控制最小的粒度是virtual host

3. 交换机exchange
交换机相当于一个具有独立进程的应用程序
接受生产者发送的消息,并根据Binding规则将消息路由给服务器中队列。
它具有一个路由表,即以key路由键-value路由,形式存储的表

4. 消息队列queue
队列,也就是存放消息的容器,遵循先进先出的规则

5. 消息Message
由Header和Body组成,Header是生产者添加的各种属性的集合,包括消息被那个Message Queue接受,优先级等属性,
body是需要传输的数据

6. 绑定binding,也叫路由规则
联系Exchange和Message Queue

7. connection连接
客户端与RabbitMQ server(broker)之间的TCP连接

8. Channel信道
客户端与broker在TCP连接后,需要为Connection创建Channel,AMQP协议规定只有Channel才能执行AMQP的命令。
一个Connection对多个Channel。建议客户端线程之间不要共用Channel,
至少要保证共用的Channel的线程发送消息必须是串行的,建议尽量共用Connection

9. AMQP命令
客户端通过Command命令完成与AMQP服务器的交互来实现自身的逻辑。
如通过publish命令发送消息,txSelect开启一个事务,txCommit提交一个事务。

note:
Exchange和多个Message Queue发生binding后形成一张路由表
当Exchange接收到Message时会解析其Header得到Routing Key,
Exchange根据Routing Key与Exchange Type将Message路由到Message Queue

Binding key由消费者在绑定Exchange和Message Queue时指定
Routing Key由Producer发送Message时指定,两者匹配方式由Exchange Type决定

ExchangeType三种类型:

三种类型分别为:

1. direct直接交换机

将交换机和队列进行绑定,当生产者producer发送消息到队列时,通过消息header中携带的Routing Key与队列进行匹配再放到队列中。

允许队列与交换机绑定的键名相同,即下图都是键一时,生产者生产的消息会同时发送到队列一和队列二。

2. Fanout广播式交换机

交换机与队列进行绑定,没有路由key,只要队列跟交换机绑定,生产者发布的消息会发不到所有队列中

3. Topic主题式交换机

与Direct直接交换类似,队列与交换机绑定的key方式使用模式匹配方式绑定

绑定的关键字(key)用另个或多个标记构成,每个标记之间用"."间隔

*号匹配一个词组,#号匹配零个或多个词组

上面三种交换模式,个人觉得第一种direct直接交换方式比较好用。

AMQP协议栈:

1. Module Layer
定义了一些供客户端调用的命令,客户端可以利用这些命令实现自己的业务逻辑,
例如,客户端可以通过queue.declare声明一个队列,利用consume命令获取一个队列中的消息。

2. Session Layer
主要负责将客户端的命令发送给服务器,在将服务器端的应答返回给客户端
主要为客户端与服务器之间通信提供可靠性、同步机制和错误处理。

3.Transport Layer
主要传输二进制数据流,提供帧的处理、信道复用、错误检测和数据表示。

参考资料来源:

RabbitMQ的几种典型使用场景(https://www.cnblogs.com/luxiaoxun/p/3918054.html)

RabbitMQ的组成、原理、安装、和eclipse的整合(https://blog.csdn.net/hongye301/article/details/85042781)

java学习-消息队列rabbitmq的组成的更多相关文章

  1. (一)RabbitMQ消息队列-RabbitMQ的优劣势及产生背景

    原文:(一)RabbitMQ消息队列-RabbitMQ的优劣势及产生背景 本篇并没有直接讲到技术,例如没有先写个Helloword.我想在选择了解或者学习一门技术之前先要明白为什么要现在这个技术而不是 ...

  2. ASP.NET Core消息队列RabbitMQ基础入门实战演练

    一.课程介绍 人生苦短,我用.NET Core!消息队列RabbitMQ大家相比都不陌生,本次分享课程阿笨将给大家分享一下在一般项目中99%都会用到的消息队列MQ的一个实战业务运用场景.本次分享课程不 ...

  3. 消息队列rabbitmq/kafka

    12.1 rabbitMQ 1. 你了解的消息队列 rabbitmq是一个消息代理,它接收和转发消息,可以理解为是生活的邮局.你可以将邮件放在邮箱里,你可以确定有邮递员会发送邮件给收件人.概括:rab ...

  4. 消息队列rabbitmq rabbitMQ安装

    消息队列rabbitmq   12.1 rabbitMQ 1. 你了解的消息队列 生活里的消息队列,如同邮局的邮箱, 如果没邮箱的话, 邮件必须找到邮件那个人,递给他,才玩完成,那这个任务会处理的很麻 ...

  5. .NET 开源工作流: Slickflow流程引擎高级开发(七)--消息队列(RabbitMQ)的集成使用

    前言:工作流流程过程中,除了正常的人工审批类型的节点外,事件类型的节点处理也尤为重要.比如比较常见的事件类型的节点有:Timer/Message/Signal等.本文重点阐述消息类型的节点处理,以及实 ...

  6. openstack (共享服务) 消息队列rabbitmq服务

    云计算openstack共享组件——消息队列rabbitmq(3)   一.MQ 全称为 Message Queue, 消息队列( MQ ) 是一种应用程序对应用程序的通信方法.应用程序通过读写出入队 ...

  7. C#中使用消息队列RabbitMQ

    在C#中使用消息队列RabbitMQ 2014-10-27 14:41 by qy1141, 745 阅读, 2 评论, 收藏, 编辑 1.什么是RabbitMQ.详见 http://www.rabb ...

  8. node使用消息队列RabbitMQ一

    基础发布和订阅 消息队列RabbitMQ使用 1 安装RabbitMQ服务器 安装erlang服务 下载地址 http://www.erlang.org/downloads 安装RabbitMQ 下载 ...

  9. 消息队列--RabbitMQ(一)

    1.消息队列概述 可以理解为保存消息的一个媒介/或者是个容器,与之相关有两个概念(即生产者(Publish)与消费者(Consumer)).所谓生产者,就是生产创造消息的一方,那么,消费者便是从队列中 ...

随机推荐

  1. 这里有一篇简单易懂的webSocket 快到碗里来~

    这篇文章是我在学习的时候看到的  刚开始还不是很理解  后来自己百度 又问了一些人  回过头在看这篇文章 真的挺好的 但是原创已经不知道是谁了  转载哦~~~ -------------------- ...

  2. pc send instructor pc ad

     1. #include <string.h> #include <intrins.h> // 加入此头文件后,可使用_nop_库函数 #define MAIN_Fosc 11 ...

  3. js--sort()排序方法的使用--(笔记)

    情况1: var arr = [ 'c', 'd', 'a', 'e' ];      //都是字母的情况arr.sort();//alert( arr );                     ...

  4. Maven依赖及范围

    一.依赖范围(scope): 共5种,compile (编译).test (测试).runtime (运行时).provided.system compile:编译依赖范围,在编译,测试,运行时都需要 ...

  5. 登录服务器失败 IP 统计和处理方法

    一.登录ssh失败次数统计 1)错误的打开方式 awk '/Failed password/ {print $(NF-3)}' secure |sort -n |uniq -c|sort -n |ta ...

  6. 别人的Linux私房菜(11)认识与学习BASH

    Linux下使用BASH   Bourne Again Shell        另外一种由用于Unix的伯克利大学的Bill Joy设计的C Shell 系统中合法的shell会写入到/etc/sh ...

  7. MySQL之二 yum安装及初识

      安装   yum install mysql-server chkconfig -list mysqld 查看mysqld服务是否为开机启动 chkconfig mysqld on 设为开机启动 ...

  8. Python开发——2.基本数据类型之数字和字符串

    一.基本数据类型 基本数据类型包括:数字(int).字符串(str).列表(list).元祖(tuple).字典(dict).布尔值(bool). 查看输出数据的类型 a = "123&qu ...

  9. JDK、JRE、JVM之间的关系

       JDK.JRE.JVM之间的关系 1.JDK下载地址 http://www.oracle.com/technetwork/java/javase/downloads/jdk8-downloads ...

  10. Transport Layer Protocols

    1 End-to-end Protocols(端到端协议) 传输层协议往往是主机对主机(host-to-host)或者说是端到端(end-to-end).通常希望传输层协议可以提供如下service: ...