rabbitMQ消息转换器

消息转换器

Spring的消息发送代码接收的消息体是一个Object:

而在数据传输时,它会把你发送的消息序列化为字节发送给MQ,接收消息的时候,还会把字节反序列化为Java对象。

只不过,默认情况下Spring采用的序列化方式是JDK序列化。众所周知,JDK序列化存在下列问题:

  • 数据体积过大
  • 有安全漏洞
  • 可读性差

我们来测试一下。

测试默认转换器

创建测试队列

我们在consumer服务中声明一个配置类,MessageConfig,里面编写方法创建队列。

java 复制代码
@Configuration
public class MessageConfig {

    @Bean
    public Queue objectQueue(){
        return new Queue("object.queue");
    }
}

重启consumer服务,看看rabbit控制台。

发送map消息

在consumer服务中,新增ObjectQueueTest类,发送消息。

java 复制代码
@SpringBootTest
public class ObjectQueueTest {
    @Autowired
    private RabbitTemplate rabbitTemplate;

    @Test
    public void testSendObjectQueue(){
        // 1 队列
        String queueName = "object.queue";
        // 2 消息
        Map<String,Object> map = new HashMap<>();
        map.put("name","sde");
        map.put("age",18);
        // 3 发送消息
        rabbitTemplate.convertAndSend(queueName,map);
    }
}

看看控制台是否有消息

查看消息

可以看到消息格式非常不友好。

配置JSON转换器

添加依赖

显然,JDK序列化方式并不合适。我们希望消息体的体积更小、可读性更高,因此可以使用JSON方式来做序列化和反序列化。

在publisher和consumer两个服务中都引入依赖

XML 复制代码
<dependency>
  <groupId>com.fasterxml.jackson.core</groupId>
  <artifactId>jackson-databind</artifactId>
</dependency>

注意:如果项目中引入了spring-boot-starter-web依赖,则无需再次引入Jackson依赖。

配置消息转换器

配置消息转换器,在publisher和consumer两个服务的启动类中添加一个Bean即可。

在PublisherApplication启动类中添加

java 复制代码
@SpringBootApplication
public class PublisherApplication {
    public static void main(String[] args) {
        SpringApplication.run(PublisherApplication.class);
    }

    @Bean
    public MessageConverter messageConverter(){
        // 1 定义消息转换器
        Jackson2JsonMessageConverter jjmc = new Jackson2JsonMessageConverter();
        //2、配置每条消息自动创建id;用于识别不同消息,也可以在页面中基于id判断是否是重复消息
        jjmc.setCreateMessageIds(true);
        return jjmc;
    }

}

在ConsumerApplication 启动类添加如下

java 复制代码
@SpringBootApplication
public class ConsumerApplication {
    public static void main(String[] args) {
        SpringApplication.run(ConsumerApplication.class, args);
    }

    @Bean
    public MessageConverter messageConverter(){
        // 1 定义消息转换器
        Jackson2JsonMessageConverter jjmc = new Jackson2JsonMessageConverter();
        //2、配置每条消息自动创建id;用于识别不同消息,也可以在页面中基于id判断是否是重复消息
        jjmc.setCreateMessageIds(true);
        return jjmc;
    }

}

测试

① 在rabbitMQ的控制台中删除 object.queue 队列中的消息;重新启动 consumer

② 执行 com.sde.publisher.ObjectQueueTest类里面的方法,发送消息。

③ 在rabbitMQ的控制台中;查看消息

删除队列里面的消息

重启了 consumer服务

再次发送了一条消息

控制台查看消息

消费者接收Object

我们在consumer服务中定义一个新的消费者,publisher是用Map发送,那么消费者也一定要用Map接收。

新创建 ObjectQueueListener 类,编写代码接收消息。

java 复制代码
@Slf4j
@Component
public class ObjectQueueListener {

    /**
     * 监听 object.queue 队列中的消息。
     */
    @RabbitListener(queues = "object.queue")
    public void listenObjectQueue(Map<String,Object> map){
        System.out.println("【消费者】监听到 object.queue 队列的消息:"+map);
    }
}

控制台

相关推荐
熏鱼的小迷弟Liu20 分钟前
【消息队列】RabbitMQ的基本架构?
面试·架构·rabbitmq
Msshu1236 小时前
Type-C 多协议快充诱骗电压芯片XSP28 芯片脚耐压高达21V 电路简单 性价比高
mongodb·zookeeper·rabbitmq·flume·memcache
Sumlll_6 小时前
Ubuntu系统下QEMU的安装与RISC-V的测试
linux·ubuntu·risc-v
毕设源码-郭学长7 小时前
【开题答辩全过程】以 基于SpringBoot技术的美妆销售系统为例,包含答辩的问题和答案
java·spring boot·后端
猫头虎7 小时前
2025最新OpenEuler系统安装MySQL的详细教程
linux·服务器·数据库·sql·mysql·macos·openeuler
梨落秋霜7 小时前
Python入门篇【文件处理】
android·java·python
Java 码农7 小时前
RabbitMQ集群部署方案及配置指南03
java·python·rabbitmq
哈库纳玛塔塔7 小时前
放弃 MyBatis,拥抱新一代 Java 数据访问库
java·开发语言·数据库·mybatis·orm·dbvisitor
S***q3778 小时前
Spring Boot管理用户数据
java·spring boot·后端
天“码”行空8 小时前
java面向对象的三大特性之一多态
java·开发语言·jvm