rabbitmq生产与消费

一、rabbitmq发送消息

一、简单模式

概述

复制代码
     一个生产者一个消费者

模型

代码

java 复制代码
//没有交换机,两个参数为routingKey和消息内容
rabbitTemplate.convertAndSend("test1_Queue","haha");

二、工作队列模式

概述

复制代码
  一个生产者,多个消费者,消费者之间负载均衡

模型

代码

java 复制代码
	//没有交换机,两个参数为routingKey和消息内容
    rabbitTemplate.convertAndSend("test1_Queue","haha");

三、发布订阅模式

概述

复制代码
生产者把消息给交换机,交换机把消息推送给与它绑定的所有队列,消费者监听自己的队列

模型

代码

java 复制代码
//该模式下,交换机与队列绑定无需routingkey,因此效率最高
rabbitTemplate.convertAndSend("fanout_Exchange","","lala");

四、路由模式

概述

复制代码
交换机与队列由routing key绑定,生产者发送消息时指定交换机和routing key,则对应的队列便会收到消息

模型

代码

java 复制代码
 rabbitTemplate.convertAndSend("direct_Exchange","test1_Queue","lala");

五、主题模式(通配符模式)

概述

复制代码
交换机与队列由routing key绑定,但routing key由通配符和具体的字符组成,生产者输入具体的字符,交换机根据routing key的规则模糊匹配到对应的队列,则对应的队列会收到消息

模型

代码

java 复制代码
/**
 * 交换机与队列绑定
 * @return
 */
@Bean
Binding truckHistoryBinding(){
    return BindingBuilder.bind(test1Queue()).to(topicExchange()).with("*.test1.*");
}


@GetMapping("/sendMessage")
public void sendMessage() {
	//需要字符串的模糊匹配,效率最低
    rabbitTemplate.convertAndSend("topic_Exchange","aa.test1.cc","lala");
}

二、rabbitmq接收消息

一、拉模式

概述

复制代码
 消费者可以主动拉取队列里的消息

代码

java 复制代码
rabbitTemplate.execute(channel->{
    //通过channel.basicGet方法可以单条获取消息,其返回值时GetReponse
    GetResponse response =  channel.basicGet("my_queue",false);
    String message = new String(response.getBody());
  }
)

二、推模式

概述

复制代码
通过发布订阅模式,订阅队列里的消息

代码

java 复制代码
 @RabbitListener(queues="my_queue")
 public void onMessage(Message messge,Channel channel){
    String msg = new String (message.getBody());
 }

三、消息的手动确认

注意:

手动确认需要先将自动确认的配置注释掉;

消息确认模式有:

AcknowledgeMode.NONE:自动确认

AcknowledgeMode.AUTO:根据情况确认

AcknowledgeMode.MANUAL:手动确认

默认情况下消息消费者是自动 ack (确认)消息的,如果要手动 ack(确认)则需要修改确认模式为 manual

java 复制代码
spring:
  rabbitmq:
    listener:
      simple:
        acknowledge-mode: manual

或在 RabbitListenerContainerFactory 中进行开启手动 ack

java 复制代码
@Bean
public RabbitListenerContainerFactory<?> rabbitListenerContainerFactory(ConnectionFactory connectionFactory){
    SimpleRabbitListenerContainerFactory factory = new SimpleRabbitListenerContainerFactory();
    factory.setConnectionFactory(connectionFactory);
    factory.setMessageConverter(new Jackson2JsonMessageConverter());
    factory.setAcknowledgeMode(AcknowledgeMode.MANUAL);             //开启手动 ack
    return factory;
}

消费消息手动确认的监听器

获取消息消费的唯一标识

java 复制代码
message.getMessageProperties().getDeliveryTag();

执行业务处理

消息确认

java 复制代码
  //消费消息的手动确认,消息确认成功-basicAck
  //第一个参数deliveryTag,消息的唯一标识
  //第二个参数multiple,消息是否支持批量确认,如果是true,代表可以一次性确认标识小于等于当前标识的所有消息
  //如果是false,只会确认当前消息
   channel.basicAck(deliveryTag,false);

消息确认失败处理,根据条件判断设置是否重回队列 ,是否支持批量处理

java 复制代码
  			//说明消费消息处理失败,如果不进行确认(自动确认,投递成功即确认,消费是否正常,不关心),消息就会丢失
            //消息处理失败确认,代表消息没有正确消费,注意:此种方式一次只能确认一个消息
            //第一给参数是消息的唯一标识,
            //第二个参数是代表是否重回队列,如果是true,重新将该消息放入队列,再次消费
            //注意:第二个参数要谨慎,必须要结合具体业务场景,根据业务判断是否需要重回队列,一旦处理不当,机会导致消息循环入队,消息挤压
            //不重回队列 require = false
//            channel.basicReject(deliveryTag,false);
            //重回队列 require = true
            channel.basicReject(deliveryTag,true);

            //消息处理失败确认,代表消息没有正确消费,注意,此种方式支持批量
            //第一个参数是消息的唯一标识,
            //第二个参数是代表是否支持批量确认
            //第三给参数代表是否重回队列
            //不重回队列 require = false
           channel.basicNack(deliveryTag,true,false);
            //重回队列 require = true
           channel.basicNack(deliveryTag,false,true);
相关推荐
爬山算法5 小时前
Redis(167)如何使用Redis实现分布式缓存?
redis·分布式·缓存
NPE~5 小时前
面试高频——分布式事务详解
分布式·面试·职场和发展·程序员·事务·分布式事务
西岭千秋雪_5 小时前
MySQL集群搭建
java·数据库·分布式·mysql
华仔啊6 小时前
RebbitMQ 入门教程看这一篇就够了
java·后端·rabbitmq
源代码•宸8 小时前
分布式缓存-GO(项目整体架构简介、Ubuntu 22.04 64位安装GoLang、安装Docker、解决Go module 的依赖问题)
经验分享·分布式·后端·ubuntu·缓存·docker·golang
Ttang239 小时前
【SpringCloud1】从单体架构到分布式系统架构
分布式·spring cloud·架构
博语小屋10 小时前
生产者消费者模型
linux·分布式·缓存
JIAWAP12 小时前
Redis数据安全性分析之RDB详解
数据库·redis·分布式·缓存
唐僧洗头爱飘柔952712 小时前
【区块链技术(04)】区块链核心技术:分布式网络的定义和特点;分布式账本的特性、实现与工作流程;共识机制
网络·分布式·区块链·共识算法·分布式账本·共识机制
松☆12 小时前
OpenHarmony + Flutter 混合开发进阶:实现跨设备分布式数据同步与状态共享
分布式·flutter