RabbitMQ知识梳理
基本概念
生产者和消费者、队列、交换机、路由键、绑定
交换机类型:
- fanout 广播模式,效率高,不处理路由键
- direct 路由模式,处理路由键,1vs1
- topic 主题模式,匹配路由键,1vs多
- headers模式,效率差,不用
RabbitMQ 运转流程:
生产者发送消息过程:
- 连接到 RabbitMQ Broker 建立一个连接( Connection) ,开启信道 (Channel)
- 声明交换器 ,设置相关属性
- 声明队列,设置相关属性
- 通过路由键将交换器和队列绑定起来
- 发送消息至 RabbitMQ Broker ,其中包含路由键、交换器等信息
- 相应的交换器根据接收到的路由键查找相匹配的队列
- 如果找到 ,则将从生产者发送过来的消息存入相应的队列中
- 如果没有找到 ,则根据生产者配置的属性选择丢弃还是回退给生产者
- 关闭信道和连接
消费者接收消息的过程:
- 连接到 RabbitMQ Broker ,建立一个连接(Connection ,开启 个信道(Channel)
- 向 RabbitMQ Broker 请求消费相应队列中的消息,可能会设置相应的回调函数,以及做些准备工作
- 等待 RabbitMQ Broker 回应并投递相应队列中的消息, 消费者接收消息
- 消费者确认(ack)接收到的消息
- RabbitMQ 从队列中删除相应己经被确认的消息
- 关闭信道和连接
AMQP协议
即Advanced Message Queuing Protocol,一个提供统一消息服务的应用层标准高级消息队列协议
入门使用
安装环境:
- windows安装(最简单,适合初学者)
- linux安装(标准和推荐方式,生产使用)
- docker安装(最最简单,前提是会docker)
交换机和队列:
- exchangeDeclare 声明交换机
- queueDeclare 声明队列
- queueBind 队列绑定
- exchangeBind 交换机绑定
- basicPublish 发送消息
- basicConsume 消费消息
- basicAck 消息确认
- basicReject 拒绝1条
- basicNack 拒绝多条
进阶使用
消息去从
- 正常消费,从队列中移除
- 被拒绝(Reject或Nack),进入死信队列
- 未被确认confirm,重回队列(mandatory、basicRecover)
- 消息超时TTL(Time to Live 的简称,即过期时间),进入死信队列
消息确认投递
- 生产者通过事务确认,性能低
- 消费者通过confirm确认,推荐
消息防止丢失
- 备份交换机,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 " , "");
- 死信队列
- 镜像队列
- 持久化 druable
过期时间 (TTL)
- 队列设置, 队列中所有消息都有相同的过期时间
Map<String, Object> argss = new HashMap<String , Object>();
argss.put("x-message-ttl " , 6000);
channel . queueDeclare(queueName , durable , exclusive , autoDelete , argss) ;
- 消息设置,对消息本身进行单独设置,每条消息的 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知识梳理的更多相关文章
- [SQL] SQL 基础知识梳理(一)- 数据库与 SQL
SQL 基础知识梳理(一)- 数据库与 SQL [博主]反骨仔 [原文地址]http://www.cnblogs.com/liqingwen/p/5902856.html 目录 What's 数据库 ...
- [SQL] SQL 基础知识梳理(二) - 查询基础
SQL 基础知识梳理(二) - 查询基础 [博主]反骨仔 [原文]http://www.cnblogs.com/liqingwen/p/5904824.html 序 这是<SQL 基础知识梳理( ...
- [SQL] SQL 基础知识梳理(三) - 聚合和排序
SQL 基础知识梳理(三) - 聚合和排序 [博主]反骨仔 [原文]http://www.cnblogs.com/liqingwen/p/5926689.html 序 这是<SQL 基础知识梳理 ...
- [SQL] SQL 基础知识梳理(四) - 数据更新
SQL 基础知识梳理(四) - 数据更新 [博主]反骨仔 [原文]http://www.cnblogs.com/liqingwen/p/5929786.html 序 这是<SQL 基础知识梳理( ...
- [SQL] SQL 基础知识梳理(五) - 复杂查询
SQL 基础知识梳理(五) - 复杂查询 [博主]反骨仔 [原文]http://www.cnblogs.com/liqingwen/p/5939796.html 序 这是<SQL 基础知识梳理( ...
- solr DIH 知识梳理
solr DIH 知识梳理 web.xml中listener配置 <listener> <listener-class>org.apache.solr.handler.data ...
- Anliven - 基础知识梳理汇总 - 软件测试
基础知识梳理 - 软件测试 - 概念 基础知识梳理 - 软件测试 - 分类 基础知识梳理 - 软件测试 - 流程 基础知识梳理 - 软件测试 - 用例 基础知识梳理 - 软件测试 - 方法 基础知识梳 ...
- [C# 基础知识梳理系列]专题六:泛型基础篇——为什么引入泛型
引言: 前面专题主要介绍了C#1中的2个核心特性——委托和事件,然而在C# 2.0中又引入一个很重要的特性,它就是泛型,大家在平常的操作中肯定会经常碰到并使用它,如果你对于它的一些相关特性还不是很了解 ...
- java基础知识梳理
java基础知识梳理 1 基本数据类型
随机推荐
- [技术博客]利用第三方框架react-native-swipeout实现左右滑动出现按钮
在之前的开发中,为了实现用户不同手势操作能够对应不同的功能,我们考虑使用React-Native的API--PanResponder,实现识别用户的手势,实现不同的功能.但我们很快就发现,这样简单的实 ...
- mpvue中按需引入echarts
大家都知道小程序文件大小不能超过2M, 在项目中引入echarts后,文件大小远远超出2M了.因为echarts文件默认是包含所有图表代码的,所以文件体积会比较大.解决办法如下: 安装 首先我们先安装 ...
- 超实用!手把手教你如何用MSF进行后渗透测试!
在对目标进行渗透测试的时候,通常情况下,我们首先获得的是一台web服务器的webshell或者反弹shell,如果权限比较低,则需要进行权限提升:后续需要对系统进行全面的分析,搞清楚系统的用途:如果目 ...
- crc64
oss2\models.py class PartInfo(object): """表示分片信息的文件. 该文件既用于 :func:`list_parts < ...
- Running MYSQL 5.7 By Bash On Ubuntu On Windows:ERROR 2002 (HY000): Can't connect to local MySQL server through socket '/var/run/mysqld/mysqld.sock' (2)
root@PC-RENGUOQIANG:/usr/sbin# /etc/init.d/mysql start * Starting MySQL database server mysqld [ OK ...
- 案例:执行 JavaScript 语句
隐藏百度图片 # coding=utf-8 from selenium import webdriver driver = webdriver.PhantomJS(executable_path=r' ...
- 人脸识别(基于ArcFace)
我们先来看看效果 上面是根据图片检测出其中的人脸.每个人脸的年龄还有性别,非常强大 第一步: 登录https://ai.arcsoft.com.cn/,注册开发者账号,身份认证,注册应用,得到APPI ...
- 第一本docker书 学习笔记(二)
#安装docker的先决条件 运行64位CPU构架的计算机(docker目前不支持32位的cpu) 运行LUFSinux3.8或者更高版本内核 内核必须支持一种合适的存储驱动,例如: device M ...
- EasyDSS高性能RTMP、HLS(m3u8)、HTTP-FLV、RTSP流媒体服务器解决方案之Grunt的使用简介
什么是Grunt? Grunt,简而言之,就是运行在Node.js上面的任务管理器(task runner),其可以在任何语言和项目中自动化指定的任务.我们可通过npm来安装Grunt和Grunt插件 ...
- rc.local添加tomcat服务启动命令,但是tomcat服务无法正常启动
遇到了一个特别坑的问题. 本来想着在rc.local文件里添加tomcat启动命令,使tomcat开机自启.之前在其他服务器上直接这样操作是没问题的,但很幸运的是,现在忽然就不行了. 开始排错: 1. ...