1、RabbitMQ中mandatory和immediate以及备份交换机

(1)mandatory为true时,若交换机无法根据自身类型和路由键找到符合条件的对列,那么RabbitMQ会回调Basic.Return将消息返回生产者。

  生产者可以调用channel.addReturnListener来添加ReturnListener实现获取被返回的消息。  

  channel.basicPublish(EXCHANGE NAME , "", true ,MessageProperties . PERSISTENT TEXT PLAIN ,"mandatory test" . getBytes());

  channel.addReturnListener(new ReturnListener() (

    public void handleReturn(int replyCode , String replyText ,String exchange , String routingKey ,AMQP.BasicProperties basicProperties ,byte[] body) throws IOException{

      String message = new String(body);

      System.out.print("返回结果是:"+message);

    }

  });

(2)mandatory为false时,若交换机无法根据自身类型和路由键找到符合条件的对列,那么RabbitMQ会丢弃消息。

(3)immediate为true时,若交换机发现队列上不存在消费者时,那么消息不会存入队列,,那么RabbitMQ会回调Basic.Return将消息返回生产者。Rabbit3.0开始不使用immediate。

(4)immediate和mandatory的差别

  mandatory告诉服务器至少将消息存储到一个队列中,否则将消息返回生产者。

  immediate告诉服务器若队列上有消费者则存储,否则将消息返回生产者。

(5)备份交换机,简称AE,生产者在发送消息时,未规定mandatory参数或mandatory参数为false时,消息服务器未找到对应的对列,会将消息丢弃,而生产者不想消息被丢弃,这时可以将消息存储到备份交换机(AE)中。

  实现备份交换机有两种方式:

  1)声明交换器(channel.exchangeDeclare)时添加alternate-exchange参数来实现。 

    Map<String , Object> args = new HashMap <String , Object>();
    args.put("alternate-exchange" , "myAe");
    channe1.exchangeDeclare( "ExchangeName" , " direct" , true , false , args);
    channe1.exchangeDeclare( "myAe " , "fanout" , true , false , null) ;

  2)通过策略(Policy)的方式来实现。

  rabbitmqctl set_policy AE “^normalExchange” '{“alternate-exchange” :"myAE"," " }'

2、过期时间(TTL)

设置消息的过期时间,有两种方式:

1)通过对列属性来设置,这样队列中所有消息的过期时间是一样的。

  Map<String , Object> args = new HashMqp<String , Object>{};

  args . put( " x-expires" , 1800000);

  channel . queueDeclare("myqueue " , false , false , false , args) ;

2)通过对每条消息来设置过期时间。

  AMQP . BasicProperties.Builder builder = new AMQP.BasicProperties . Builder();

  builder.deliveryMode(2);//持久化消息

  builder.expiration(“6000”);//设置过期时间

  AMQP.BasicProperties properties = builder . build() ;channel.basicPublish(exchangeName , routingKey , mandatory , properties ," ttlTestMessage".getBytes());

两种都设置过期时间时,取最短时间,超过过期时间,消息就会变成死信。

3、死信队列、延迟队列、优先级队列

(1)死信队列,简称DLX,当消息被拒绝、过期、队列达到最大长度时,消息就会变成死信,而死信就会被存储在死信队列里。

  死信队列可以在队列属性中设置:

  channel . exchangeDeclare("dlx_exchange " ,“direct”);//创建direct类型交换机

  Map<String , Object> args = new HashMap<String , Object>();
  args . put("x-dead-letter-exchange" , " dlx_exchange ");//设置交换机属性
  channel . queueDeclare("myqueue" , false , false , false , args);//将myqueue设置为死信对列

(2)延迟队列,生产者发出消息后想在特定的时间让消费者获取消息,可以在发消息时设置消息延迟时间。

  可以通过死信得方式来实现消息延迟,例如当生产者通过A1交换机把消息发送到B1队列上,设置过期时间为20秒,当消息过期后,会存储到死信队列B2上,而消费者去订阅B2对列,从而实现消息延迟。

(3)优先级队列,优先级高的对列中存储的消息会被最先消费。

  Map<String , Object> args= new HashMap<String , Object>() ;

  args.put( " x-rnax-priority " , 10) ;//设置优先级为10

  channel.queueDeclare( " Queue_priority " , true , false , false , args) ;

4、远程过程调用(RPC)

  通过远程计算机从网络发起服务请求,有助于降低分布式的构建难度。

  RabbitMQ实现RPC,客户端发送请求消息,为每一条消息指定唯一的ID,服务端回复响应消息,为了接收相应的消息,需要在请求消息中发送一个回调对列,回调对列收到服务端返回的消息后根据ID来将返回消息和请求消息进行匹配,如果匹配失败,回复消息会被丢弃,RPC的流程图如下:

5、消息持久化

  消息持久化可以提高RabbitMQ的可靠性,以防在重启、宕机时发生的数据丢失,RabbitMQ中持久化可分为交换器持久化、对列持久化、消息持久化。

  交换器持久化:声明交换器时把durable设置为true,交换器持久化会保证消息不会丢失,但自身的数据会丢失,无法再将消息发送到交换器上。

  对列持久化:声明对列时把durable设置为true,对列持久化可以保证自身的数据不会丢失,但存储的消息会丢失。

  消息持久化:将消息发送模式BasicProperties中的deliveryMode设置为2,重启、宕机消息不会丢失。

  对列和消息、交换器都设置持久化,会很大概率保证数据不会丢失,但是会影响效率,因为持久化会将数据写到磁盘里。

 

RabbitMQ小记(三)的更多相关文章

  1. RabbitMQ(三) -- Publish/Subscribe

    RabbitMQ(三) -- Publish/Subscribe `rabbitmq`支持一对多的模式,一般称为发布/订阅.也就是说,生产者产生一条消息后,`rabbitmq`会把该消息分发给所有的消 ...

  2. rabbitMQ第三篇:采用不同的交换机规则

    在上一篇我们都是采用发送信息到队列然后队列把信息在发送到消费者,其实实际情况并非如此,rabbitMQ其实真正的思想是生产者不发送任何信息到队列,甚至不知道信息将发送到哪个队列.相反生产者只能发送信息 ...

  3. python使用rabbitMQ介绍三(发布订阅模式)

    一.模式介绍 在前面的例子中,消息直接发送到queue中. 现在介绍的模式,消息发送到exchange中,消费者把队列绑定到exchange上. 发布-订阅模式是把消息广播到每个消费者,每个消费者接收 ...

  4. 【RabbitMQ】三种类型交换器 Fanout,Direct,Topic(转)

    出处:https://blog.csdn.net/fxq8866/article/details/62049393 RabbitMQ服务器会根据路由键将消息从交换器路由到队列中,如何处理投递到多个队列 ...

  5. rabbitMQ的三种路由模式

    rabbitMQ工作流程: 1.声明交换机 2.声明消息队列 3.绑定交换机和队列 4.生产者往交换机里发送新消息 5.交换机根据所选的模式和routingKey决定消息发往哪条消息队列 6.一个消费 ...

  6. RabbitMQ系列(三)--Java API

    基于java使用RabbitMQ 框架:SpringBoot1.5.14.RELEASE maven依赖: <dependency> <groupId>com.rabbitmq ...

  7. RabbitMQ实战(三)-高级特性

    0 相关源码 1 你将学到 如何保证消息百分百投递成功 幂等性 如何避免海量订单生成时消息的重复消费 Confirm确认消息.Return返回消息 自定义消费者 消息的ACK与重回队列 限流 TTL ...

  8. RabbitMQ(三):RabbitMQ与Spring Boot简单整合

    RabbitMQ是目前非常热门的一款消息中间件,不管是互联网大厂还是中小企业都在大量使用.Spring Boot的兴起,极大地简化了Spring的开发,本文将使用Spring Boot与RabbitM ...

  9. 消息中间件——RabbitMQ(三)理解RabbitMQ核心概念和AMQP协议!

    前言 本章学习,我们可以了解到以下知识点: 互联网大厂为什么选择RabbitMQ? RabbiMQ的高性能之道是如何做到的? 什么是AMQP高级协议? AMQP核心概念是什么? RabbitMQ整体架 ...

随机推荐

  1. Java枚举简述

    Java 枚举(enum) Java 枚举是一个特殊的类,一般表示一组常量,比如一年的 4 个季节,一个年的 12 个月份,一个星期的 7 天,方向有东南西北等. Java 枚举类使用 enum 关键 ...

  2. seo如何发外链

    http://www.wocaoseo.com/thread-228-1-1.html 在做外链方面博主并没有什么太多的经验,做为一位seo,下面武汉seo把自己做外链的大条列出来,都是经过本身实践并 ...

  3. asterisk PBX 对接中国移动IMS

    前提: 最近有项目需求,需要对接移动的IMS,移动的对接同事给出了信息: 用户名:+86750735xxxx@ims.gd.chinamobile.com  密码:123456 (系统导入的号码,默认 ...

  4. TinkPHP框架开发的CRMEB小程序商城v4.0二次开发集成支付宝支付

    前言 大家都知道支付宝支付和微信支付宝都只能局限在自己的平台,微信内支付宝支付是根本就不能使用,即使是公众号支付也需要跳转到外部浏览器才可以唤起支付宝支付,并且QQ浏览器唤起支付宝支付还是问题很多,所 ...

  5. Flutter —布局系统概述

    老孟导读:此篇文章非常详细的讲解了 Flutter 布局系统的工作原理. 翻译自:https://itnext.io/flutter-layout-system-overview-c70bbe9ba9 ...

  6. Codeforces 1324F Maximum White Subtree DFS

    题意 给你无根一颗树,每个节点是黑色或白色.对于每一个节点,问包含该节点的权值最大的子树. 子树的权值等于子树中白点的个数减去黑点的个数. 注意,这里的子树指的是树的联通子图. 解题思路 这场就这题卡 ...

  7. 没事也来配一个logback

    工程下载:https://files.cnblogs.com/files/xiandedanteng/logbackCfg20200115.zip 首先创建一个maven项目,pom.xml如下书写: ...

  8. 微信小程序 部署(后台是springboot项目 前后台分流)

    微信小程序的部署需要https 和证书: https 需要反向代理: 这里用 nginx,无论linux,windows 系统都可以安装: 1.安装nginx ,这步自己去做: linux 安装ngi ...

  9. 安装最新LAMP环境(CentOS7+PHP7.1.5+Mysql5.7)

    安装Apache&Nginx ①.升级一下yum源(不是必须的),升级会花点时间,需要选择的地方都选择都输入“y”即可 yum update ②. 安装Apache yum list |gre ...

  10. hadoop和hbase高可用模式部署

    记录apache版本的hadoop和hbase的安装,并启用高可用模式. 1. 主机环境 我这里使用的操作系统是centos 6.5,安装在vmware上,共三台. 主机名 IP 操作系统 用户名 安 ...