RabbitMQ

基本概念

生产者和消费者、队列、交换机、路由键、绑定

交换机类型:

  • fanout 广播模式,效率高,不处理路由键
  • direct 路由模式,处理路由键,1vs1
  • topic 主题模式,匹配路由键,1vs多
  • headers模式,效率差,不用

RabbitMQ 运转流程:

生产者发送消息过程:

  1. 连接到 RabbitMQ Broker 建立一个连接( Connection) ,开启信道 (Channel)
  2. 声明交换器 ,设置相关属性
  3. 声明队列,设置相关属性
  4. 通过路由键将交换器和队列绑定起来
  5. 发送消息至 RabbitMQ Broker ,其中包含路由键、交换器等信息
  6. 相应的交换器根据接收到的路由键查找相匹配的队列
  7. 如果找到 ,则将从生产者发送过来的消息存入相应的队列中
  8. 如果没有找到 ,则根据生产者配置的属性选择丢弃还是回退给生产者
  9. 关闭信道和连接

消费者接收消息的过程:

  1. 连接到 RabbitMQ Broker ,建立一个连接(Connection ,开启 个信道(Channel)
  2. 向 RabbitMQ Broker 请求消费相应队列中的消息,可能会设置相应的回调函数,以及做些准备工作
  3. 等待 RabbitMQ Broker 回应并投递相应队列中的消息, 消费者接收消息
  4. 消费者确认(ack)接收到的消息
  5. RabbitMQ 从队列中删除相应己经被确认的消息
  6. 关闭信道和连接

AMQP协议

即Advanced Message Queuing Protocol,一个提供统一消息服务的应用层标准高级消息队列协议

入门使用

安装环境:

  1. windows安装(最简单,适合初学者)
  2. linux安装(标准和推荐方式,生产使用)
  3. docker安装(最最简单,前提是会docker)

交换机和队列:

  • exchangeDeclare 声明交换机
  • queueDeclare 声明队列
  • queueBind 队列绑定
  • exchangeBind 交换机绑定
  • basicPublish 发送消息
  • basicConsume 消费消息
  • basicAck 消息确认
  • basicReject 拒绝1条
  • basicNack 拒绝多条

进阶使用

消息去从

  1. 正常消费,从队列中移除
  2. 被拒绝(Reject或Nack),进入死信队列
  3. 未被确认confirm,重回队列(mandatory、basicRecover)
  4. 消息超时TTL(Time to Live 的简称,即过期时间),进入死信队列

消息确认投递

  • 生产者通过事务确认,性能低
  • 消费者通过confirm确认,推荐

消息防止丢失

  1. 备份交换机,Altemate Exchange ,简称AE
Map<String, Object> args = new HashMap<String , Object>();
args.put("a1ternate-exchange" , "myAe");
channe1.exchangeDec1are( "norma1Exchange" , "direct" , true , fa1se , args);
channe1 . exchangeDec1are( "myAe " , "fanout" , true , fa1se , nu11) ;
channe1 .queueDec1are( "norma1Queue " , true , fa1se , fa1se , nu11);
channe1 .queueB nd( norma1Queue "norma1Exchange" , " norma1Key");
channe1 .queueDec1are( "unroutedQueue " , true , fa1se , fa1se , nu11);
channel .queueBind( "unroutedQueue " , "myAe " , "");
  1. 死信队列
  2. 镜像队列
  3. 持久化 druable

过期时间 (TTL)

  1. 队列设置, 队列中所有消息都有相同的过期时间
Map<String, Object> argss = new HashMap<String , Object>();
argss.put("x-message-ttl " , 6000);
channel . queueDeclare(queueName , durable , exclusive , autoDelete , argss) ;
  1. 消息设置,对消息本身进行单独设置,每条消息的 TTL 可以不同
AMQP.BasicProperties properties = new AMQP.BasicProperties() ;
properties.setExpiration("60000");
channel . basicPublish (exchangeName, routingKey, mandatory, propertes, "ttlTestMessage".getBytes());

消息分发

  • 轮询分发(round-robin ),默认
  • 均衡分发,channel.basicQos(1)

高级队列

1.死信队列

DLX ,全称为 Dead-Letter-Exchange ,可以称之为死信交换器,也有人称之为死信邮箱。当
消息在一个队列中变成死信 (dea message) 之后,它能被重新被发送到另一个交换器中,这个
交换器就是 DLX ,绑定 DLX 的队列就称之为死信队列。

消息变成死信 般是由于以下几种情况:
1、消息被拒绝 (Basic.Reject/Basic .Na ck) ,井且设置 requeue 参数为 alse;
2、消息过期;
3、令队列达到最大长度。

channel . exchangeDeclare("dlx_exchange " , "dir ect "); // 创建 DLX: dlx_exchange
Map<String, Object> args = new HashMap<String, Object>();
args . put("x-dead-letter-exchange" , " dlx exchange ");
//为队列 myqueue 添加 DLX
channel . queueDeclare("myqueue" , false , false , false , args);
也可以为这个 DLX 指定路由键,如果没有特殊指定,则使用原队列的路由键:
args.put("x-dead-letter-routing-key" , "dlx-routing-key");

2.延迟队列

通过DLX死信队列和TTL时间过期模拟出延迟队列的功能。

3.优先队列

优先级高的消息具备优先被消费的特权,默认最低为0。如果消费速度大于生产速度,则没有意义

Map<String, Object> args =new HashMap<String, Object>() ;
args . put( "x-rnax-priority" , 10) ;
channel.queueDeclare( " queue . priority" , true , fa1se , false , args) ;

4.镜像队列

参考书籍:
《RabbitMQ 实战指南》朱忠华 著

RabbitMQ 实战指南

RabbitMQ知识梳理的更多相关文章

  1. [SQL] SQL 基础知识梳理(一)- 数据库与 SQL

    SQL 基础知识梳理(一)- 数据库与 SQL [博主]反骨仔 [原文地址]http://www.cnblogs.com/liqingwen/p/5902856.html 目录 What's 数据库 ...

  2. [SQL] SQL 基础知识梳理(二) - 查询基础

    SQL 基础知识梳理(二) - 查询基础 [博主]反骨仔 [原文]http://www.cnblogs.com/liqingwen/p/5904824.html 序 这是<SQL 基础知识梳理( ...

  3. [SQL] SQL 基础知识梳理(三) - 聚合和排序

    SQL 基础知识梳理(三) - 聚合和排序 [博主]反骨仔 [原文]http://www.cnblogs.com/liqingwen/p/5926689.html 序 这是<SQL 基础知识梳理 ...

  4. [SQL] SQL 基础知识梳理(四) - 数据更新

    SQL 基础知识梳理(四) - 数据更新 [博主]反骨仔 [原文]http://www.cnblogs.com/liqingwen/p/5929786.html 序 这是<SQL 基础知识梳理( ...

  5. [SQL] SQL 基础知识梳理(五) - 复杂查询

    SQL 基础知识梳理(五) - 复杂查询 [博主]反骨仔 [原文]http://www.cnblogs.com/liqingwen/p/5939796.html 序 这是<SQL 基础知识梳理( ...

  6. solr DIH 知识梳理

    solr DIH 知识梳理 web.xml中listener配置 <listener> <listener-class>org.apache.solr.handler.data ...

  7. Anliven - 基础知识梳理汇总 - 软件测试

    基础知识梳理 - 软件测试 - 概念 基础知识梳理 - 软件测试 - 分类 基础知识梳理 - 软件测试 - 流程 基础知识梳理 - 软件测试 - 用例 基础知识梳理 - 软件测试 - 方法 基础知识梳 ...

  8. [C# 基础知识梳理系列]专题六:泛型基础篇——为什么引入泛型

    引言: 前面专题主要介绍了C#1中的2个核心特性——委托和事件,然而在C# 2.0中又引入一个很重要的特性,它就是泛型,大家在平常的操作中肯定会经常碰到并使用它,如果你对于它的一些相关特性还不是很了解 ...

  9. java基础知识梳理

    java基础知识梳理 1 基本数据类型

随机推荐

  1. Spring Boot通过Configuration配置多数据源

    本文结合SpringBoot + MyBatis + MySql进行多数据源配置,DataSource信息采用自定义dataSource.properties进行配置. 1.文件结构如下: 2.1 p ...

  2. Oracle数据库访问客户端 sqldeveloper-18.4.0-376.1900-x64 下载

    Oracle数据库访问客户端 sqldeveloper-18.4.0-376.1900-x64 下载地址:https://pan.baidu.com/s/1RnHVuMcCNZQ7ncHLKDJ33Q

  3. numpy的文件存储.npy .npz 文件详解

    Numpy能够读写磁盘上的文本数据或二进制数据. 将数组以二进制格式保存到磁盘 np.load和np.save是读写磁盘数组数据的两个主要函数,默认情况下,数组是以未压缩的原始二进制格式保存在扩展名为 ...

  4. C++11原子操作与无锁编程(转)

    不讲语言特性,只从工程角度出发,个人觉得C++标准委员会在C++11中对多线程库的引入是有史以来做得最人道的一件事:今天我将就C++11多线程中的atomic原子操作展开讨论:比较互斥锁,自旋锁(sp ...

  5. 运维笔记--线上服务器git环境配置

    场景描述: 我们采用git去管理代码分支,本地开发环境,线上服务器多数情况下也会使用git去管理程序代码,那么新的一台服务器,如果指定了目标路径作为代码存放路径,该如何配置git环境, 以达到跟远程服 ...

  6. 阶段一-01.万丈高楼,地基首要-第2章 单体架构设计与准备工作-2-27 为何不使用@EnableTransactionManagement就能使用事务?

    使用了注解使用事务.但是没有开启注解的启用 启动类里面使用注解 @EnableTransactionManager开启事物的管理. 为什么我们没有开启这个注解,还需要在响应的Service里面使用事务 ...

  7. Executors创建四种线程池

    newCachedThreadPool创建一个可缓存线程池,如果线程池长度超过处理需要,可灵活回收空闲线程,若无可回收,则新建线程.newFixedThreadPool 创建一个定长线程池,可控制线程 ...

  8. Elasticsearch6.2.1安装elasticsearch-sq插件

    参考 https://github.com/NLPchina/elasticsearch-sql 1.下载插件 wget https://github.com/NLPchina/elasticsear ...

  9. {Redis}NOAUTH Authentication required. Linux.cenOS

    问题 [root@VM_0_12_centos redis]# ./bin/redis-cli -p 6379 127.0.0.1:6379> INFO NOAUTH Authenticatio ...

  10. QT+FFMPEG+SDL2.0实现视频播放

    开发环境:MinGW+QT5.9+FFMPEG20190212+SDL2.0.9 一.开发环境搭建 (1)下载工具 在https://ffmpeg.zeranoe.com/builds/下载对应版本. ...