【RabbitMQ 第七篇】RabbitMQ实现JSON,2024年最新身为一个大数据开发程序员Context都没弄明白

7.RabbitMQ实现JSON、Map格式数据的发送与接收

在实现的项目开发中,经常使用Json、Map格式数据。下面将介绍RabbitMQ实现Json、Map格式数据的发送与接收。

7.1消息发送端

在消息发送端服务引入依赖、yml配置、RabbitMQ配置类、消息发送类

7.1.1引入依赖
org.springframework.boot spring-boot-starter-amqp
7.1.2yml配置

spring:
application:
name: rabbitmq-provider
rabbitmq:
host: 127.0.0.1
port: 5672
username: guest
password: guest
publisher-confirm-type: correlated
publisher-returns: true

7.1.3RabbitMQConfig配置类——(非常重要)

在项目中,创建配置类,配置 消息确认Json转换器队列名称 等,并将队列交由 IoC 管理。代码如下:

package com.pjb.config;

import org.springframework.amqp.core.*;
import org.springframework.amqp.rabbit.connection.CachingConnectionFactory;
import org.springframework.amqp.rabbit.connection.ConnectionFactory;
import org.springframework.amqp.rabbit.connection.CorrelationData;
import org.springframework.amqp.rabbit.core.RabbitTemplate;
import org.springframework.amqp.support.converter.Jackson2JsonMessageConverter;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;

import java.util.HashMap;
import java.util.Map;

/**
* RabbitMQ配置类
**/
@Configuration
public class RabbitMqConfig
{
public static final String DIRECT_QUEUE = “direct_queue”; //Direct队列名称
public static final String DIRECT_EXCHANGE = “direct_exchange”; //交换器名称
public static final String DIRECT_ROUTING_KEY = “direct_routing_key”; //路由键

public static final String DELAY_QUEUE = “delay_queue”; //延时队列名称
public static final String DELAY_EXCHANGE = “delay_exchange”; //交换器名称
public static final String DELAY_ROUTING_KEY = “delay_routing_key”; //路由键

@Autowired
private CachingConnectionFactory connectionFactory;

@Bean
public RabbitTemplate createRabbitTemplate(ConnectionFactory connectionFactory)<

  • 11
    点赞
  • 12
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在Spring Boot中连接两个RabbitMQ实例并其中一个RabbitMQ上的数据转发到另一个RabbitMQ可以通过以下步骤实现: 1. 首先,确保你已经在Spring Boot项目中添加了RabbitMQ的依赖。可以在pom.xml文件中添加以下依赖: ```xml <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-amqp</artifactId> </dependency> ``` 2. 在application.properties或application.yml文件中配置两个RabbitMQ实例的连接信息。例如: ```properties # 第一个RabbitMQ实例 spring.rabbitmq.host=host1 spring.rabbitmq.port=5672 spring.rabbitmq.username=username1 spring.rabbitmq.password=password1 # 第二个RabbitMQ实例 custom.rabbitmq.host=host2 custom.rabbitmq.port=5672 custom.rabbitmq.username=username2 custom.rabbitmq.password=password2 ``` 3. 创建两个RabbitMQ连接工厂的Bean。在Spring Boot的配置类中添加以下代码: ```java @Configuration public class RabbitMQConfig { @Value("${spring.rabbitmq.host}") private String rabbitmqHost; @Value("${spring.rabbitmq.port}") private int rabbitmqPort; @Value("${spring.rabbitmq.username}") private String rabbitmqUsername; @Value("${spring.rabbitmq.password}") private String rabbitmqPassword; @Value("${custom.rabbitmq.host}") private String customRabbitmqHost; @Value("${custom.rabbitmq.port}") private int customRabbitmqPort; @Value("${custom.rabbitmq.username}") private String customRabbitmqUsername; @Value("${custom.rabbitmq.password}") private String customRabbitmqPassword; @Bean public ConnectionFactory rabbitmqConnectionFactory() { CachingConnectionFactory connectionFactory = new CachingConnectionFactory(); connectionFactory.setHost(rabbitmqHost); connectionFactory.setPort(rabbitmqPort); connectionFactory.setUsername(rabbitmqUsername); connectionFactory.setPassword(rabbitmqPassword); return connectionFactory; } @Bean public ConnectionFactory customRabbitmqConnectionFactory() { CachingConnectionFactory connectionFactory = new CachingConnectionFactory(); connectionFactory.setHost(customRabbitmqHost); connectionFactory.setPort(customRabbitmqPort); connectionFactory.setUsername(customRabbitmqUsername); connectionFactory.setPassword(customRabbitmqPassword); return connectionFactory; } } ``` 4. 创建两个RabbitMQ模板的Bean。在Spring Boot的配置类中添加以下代码: ```java @Configuration public class RabbitMQConfig { // ... @Bean public RabbitTemplate rabbitTemplate(ConnectionFactory rabbitmqConnectionFactory) { RabbitTemplate rabbitTemplate = new RabbitTemplate(rabbitmqConnectionFactory); return rabbitTemplate; } @Bean public RabbitTemplate customRabbitTemplate(ConnectionFactory customRabbitmqConnectionFactory) { RabbitTemplate rabbitTemplate = new RabbitTemplate(customRabbitmqConnectionFactory); return rabbitTemplate; } } ``` 5. 创建一个消息监听器,从第一个RabbitMQ实例接收消息,并将其发送到第二个RabbitMQ实例。例如: ```java @Component public class MessageListener { private final RabbitTemplate customRabbitTemplate; public MessageListener(RabbitTemplate customRabbitTemplate) { this.customRabbitTemplate = customRabbitTemplate; } @RabbitListener(queues = "queue1") public void receiveMessageFromFirstRabbitMQ(String message) { // 将消息发送到第二个RabbitMQ实例 customRabbitTemplate.convertAndSend("exchange2", "routingKey2", message); } } ``` 以上是一个简单的示例,通过消息监听器将第一个RabbitMQ实例上的消息转发到第二个RabbitMQ实例。你可以根据实际需求进行修改和扩展。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值