springAMQP(示例)

2024-06-03 20:36
文章标签 示例 springamqp

本文主要是介绍springAMQP(示例),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

配置:

        消费者类(接收方):

spring:rabbitmq:host: RabbitMQ的IP地址  # 主机名port: 5672 # 发送消息和接收消息的端口号virtual-host: / # 虚拟主机username: 用户名 # 用户名password: 密码 # 密码#预取 : 每次将队列中的消息发给消费者一个消息,当消费者消费完之后在给学消费者消息。那么这样做谁消费快谁就会消费更多的消息listener:simple:prefetch: 1

         消费者类(接收方):

spring:rabbitmq:host: RabbitMQ的IP地址  # 主机名port: 5672 # 发送消息和接收消息的端口号virtual-host: / # 虚拟主机username: 用户名 # 用户名password: 密码 # 密码

        引入依赖(在父工程引入或者在两个工程中同时引入):

 <!--AMQP依赖,包含RabbitMQ--><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-amqp</artifactId></dependency>

简单消息队列:

        消费者(SpringRabbitListener):

@Component
public class SpringRabbitListener {//定义监听简单消息队列simple.queue的消息/*1.RabbitListener 注解中的属性:String[] queues() default {}; 书写监听哪个队列的名字*/@RabbitListener(queues = {"simple.queue"})//@RabbitListener(queues = "simple.queue")public void listenSimpleMessage(String msg){System.out.println("消费者接收到了生产者发送的消息:"+msg);}}

        生产者:

@Autowired
private RabbitTemplate rabbitTemplate;public void testSimpleQueue() {//1.定义变量保存队列名String queueName = "simple.queue";//2.定义变量保存发送的消息String message="hello,我是锁哥,发送的基本消息";//3.发送消息rabbitTemplate.convertAndSend(queueName,message);}

广播消息队列:

        消费者:

@RabbitListener(queues = "fanout.queue1")public void listenFanout1Message(String msg){System.out.println("消费者1接收到了生产者发送的消息:"+msg);}@RabbitListener(queues = "fanout.queue2")public void listenFanout2Message(String msg){System.out.println("消费者2接收到了生产者发送的消息:"+msg);}

        消费者配置类:

@Configuration
public class FanoutConfig {//1.定义方法声明交换机,将交换机对象放到SpringIOC容器中//@Bean修饰的方法返回值对象作为SpringIOC容器中的value,方法名作为key@Beanpublic FanoutExchange fanoutExchange(){//itcast.fanout表示交换机的名字return new FanoutExchange("itcast.fanout");}//2.定义方法声明队列1@Beanpublic Queue fanoutQueue1(){//fanout.queue1 表示队列名return new Queue("fanout.queue1");}//3.定义方法将队列1绑定到交换机itcast.fanout上//下面方法的形参FanoutExchange fanoutExchange的名字和上述 public FanoutExchange fanoutExchange(){}方法名一致@Beanpublic Binding bindingQueue1ToExchange(FanoutExchange fanoutExchange,Queue fanoutQueue1){/*public Binding to(FanoutExchange exchange){}*/return BindingBuilder.bind(fanoutQueue1).to(fanoutExchange);}//4.定义方法声明队列2@Beanpublic Queue fanoutQueue2(){//fanout.queue2 表示队列名return new Queue("fanout.queue2");}//5.定义方法将队列2绑定到交换机上@Beanpublic Binding bindingQueue2ToExchange(FanoutExchange fanoutExchange,Queue fanoutQueue2){/*public Binding to(FanoutExchange exchange){}*/return BindingBuilder.bind(fanoutQueue2).to(fanoutExchange);}}

        生产者:

@Autowired
private RabbitTemplate rabbitTemplate;public void testFanoutExchange() {String exchangeName="itcast.fanout"; //1.定义变量保存交换机的名字String message="马上过年了,别慌,好好学习,找一份满意的工作,明年领媳妇回家过年"; //2.定义变量保存发送的消息//第二个参数是routingkey,这里实现的是广播交换机,不需要routingkey,因此这里是空字符串rabbitTemplate.convertAndSend(exchangeName,"",message);}

监听路由队列:

              生产者:

 @Autowired
private RabbitTemplate rabbitTemplate;public void testSendDirectExchange() {//1.定义变量保存交换机名String exchangeName = "交换机名x";//2.定义变量保存消息String message="乾坤未定,你我皆是屌丝程序员";//3.发送消息rabbitTemplate.convertAndSend(exchangeName,"路由值1",message);}

              消费者:

@RabbitListener(bindings = {@QueueBinding(value=@Queue(name="队列名"),exchange = @Exchange(name="交换机名x",type = ExchangeTypes.DIRECT),key={"路由值1","路由值2"})})public void listenDirect1Message(String msg){System.out.println("消费者1接收到了生产者发送的消息:"+msg);}

消息转换器:

        引入json(在父工程引入或者在两个工程中同时引入):

 <!--json格式的消息转换器--><dependency><groupId>com.fasterxml.jackson.dataformat</groupId><artifactId>jackson-dataformat-xml</artifactId><version>2.9.10</version></dependency>

        在消费者配置类中添加:

//将json的消息转换器对象放到IOC中@Beanpublic MessageConverter jsonMessageConverter(){return new Jackson2JsonMessageConverter();}

          生产者配置类:

@Configuration
public class MessageConverterConfig {//将json的消息转换器对象放到IOC中@Beanpublic MessageConverter jsonMessageConverter(){return new Jackson2JsonMessageConverter();}
}

        消费者:

    @RabbitListener(queues = "object.queue")public void listenObjectMessage(HashMap<String,String> map){System.out.println("消费者接收到了生产者发送的消息:"+map);}

        生产者:

@Autowired
private RabbitTemplate rabbitTemplate;public void testSendMap() throws InterruptedException {//1.定义变量保存队列名String queueName="object.queue";//2.创建Map集合对象HashMap<String, String> map = new HashMap<>();map.put("itcast001","张三");map.put("itcast002","柳岩");//3.发送消息rabbitTemplate.convertAndSend(queueName,map);}

这篇关于springAMQP(示例)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1028044

相关文章

sky-take-out项目中Redis的使用示例详解

《sky-take-out项目中Redis的使用示例详解》SpringCache是Spring的缓存抽象层,通过注解简化缓存管理,支持Redis等提供者,适用于方法结果缓存、更新和删除操作,但无法实现... 目录Spring Cache主要特性核心注解1.@Cacheable2.@CachePut3.@Ca

QT Creator配置Kit的实现示例

《QTCreator配置Kit的实现示例》本文主要介绍了使用Qt5.12.12与VS2022时,因MSVC编译器版本不匹配及WindowsSDK缺失导致配置错误的问题解决,感兴趣的可以了解一下... 目录0、背景:qt5.12.12+vs2022一、症状:二、原因:(可以跳过,直奔后面的解决方法)三、解决方

MySQL中On duplicate key update的实现示例

《MySQL中Onduplicatekeyupdate的实现示例》ONDUPLICATEKEYUPDATE是一种MySQL的语法,它在插入新数据时,如果遇到唯一键冲突,则会执行更新操作,而不是抛... 目录1/ ON DUPLICATE KEY UPDATE的简介2/ ON DUPLICATE KEY UP

Python中Json和其他类型相互转换的实现示例

《Python中Json和其他类型相互转换的实现示例》本文介绍了在Python中使用json模块实现json数据与dict、object之间的高效转换,包括loads(),load(),dumps()... 项目中经常会用到json格式转为object对象、dict字典格式等。在此做个记录,方便后续用到该方

MySQL分库分表的实践示例

《MySQL分库分表的实践示例》MySQL分库分表适用于数据量大或并发压力高的场景,核心技术包括水平/垂直分片和分库,需应对分布式事务、跨库查询等挑战,通过中间件和解决方案实现,最佳实践为合理策略、备... 目录一、分库分表的触发条件1.1 数据量阈值1.2 并发压力二、分库分表的核心技术模块2.1 水平分

SpringBoot请求参数传递与接收示例详解

《SpringBoot请求参数传递与接收示例详解》本文给大家介绍SpringBoot请求参数传递与接收示例详解,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋... 目录I. 基础参数传递i.查询参数(Query Parameters)ii.路径参数(Path Va

RabbitMQ 延时队列插件安装与使用示例详解(基于 Delayed Message Plugin)

《RabbitMQ延时队列插件安装与使用示例详解(基于DelayedMessagePlugin)》本文详解RabbitMQ通过安装rabbitmq_delayed_message_exchan... 目录 一、什么是 RabbitMQ 延时队列? 二、安装前准备✅ RabbitMQ 环境要求 三、安装延时队

Redis实现高效内存管理的示例代码

《Redis实现高效内存管理的示例代码》Redis内存管理是其核心功能之一,为了高效地利用内存,Redis采用了多种技术和策略,如优化的数据结构、内存分配策略、内存回收、数据压缩等,下面就来详细的介绍... 目录1. 内存分配策略jemalloc 的使用2. 数据压缩和编码ziplist示例代码3. 优化的

GO语言短变量声明的实现示例

《GO语言短变量声明的实现示例》在Go语言中,短变量声明是一种简洁的变量声明方式,使用:=运算符,可以自动推断变量类型,下面就来具体介绍一下如何使用,感兴趣的可以了解一下... 目录基本语法功能特点与var的区别适用场景注意事项基本语法variableName := value功能特点1、自动类型推

Java中的stream流分组示例详解

《Java中的stream流分组示例详解》Java8StreamAPI以函数式风格处理集合数据,支持分组、统计等操作,可按单/多字段分组,使用String、Map.Entry或Java16record... 目录什么是stream流1、根据某个字段分组2、按多个字段分组(组合分组)1、方法一:使用 Stri