RabbitMQ入门指南(六):消息转换器及其案例

简介: RabbitMQ是一个高效、可靠的开源消息队列系统,广泛用于软件开发、数据传输、微服务等领域。本文主要介绍了RabbitMQ默认转换器、JSON转换器及其案例等内容。

一、消息转换器

消息转换器是一个用于将消息转换为特定格式或类型的组件。在分布式系统中,消息转换器通常用于在不同的系统或服务之间进行数据传输和交互。

在Spring框架中,当消息发送者将消息发送到RabbitMQ时,如果消息体被封装为一个Object,在数据传输过程中,这个Object会被序列化为字节流,然后发送给RabbitMQ。同样,当消息接收者从RabbitMQ接收消息时,字节流会被反序列化为Java对象。

然而,默认情况下,Spring使用的是Java的序列化方式(JDK序列化)来进行这种转换。JDK序列化虽然简单易用,但也存在一些问题:

  • 数据体积过大:JDK序列化生成的数据体积相对较大,这可能会影响传输效率和存储效率。
  • 有安全漏洞:JDK序列化可能存在一些安全漏洞,例如,攻击者可能通过序列化恶意对象来执行任意代码。
  • 可读性差:JDK序列化生成的字节流难以阅读和理解,这给调试和审计带来了困难。

为了解决这些问题,可以使用其他的序列化方式,例如JSON序列化等。

二、RabbitMQ默认转换器案例(省略交换机)

在consumer服务中声明队列:

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

image.gif

在publisher服务中编写测试类,实现消息发送

@Test
    void testSendObject() {
        Map<String, Object> msg = new HashMap<>(2);
        msg.put("username", "user");
        msg.put("password", 123456);
        rabbitTemplate.convertAndSend("object.queue", msg);
    }

image.gif

运行后在RabbitMQ管理控制台查看消息


三、JSON转换器案例(省略交换机)

1.配置JSON转换器

在publisher和consumer两个服务(父工程)中引入Jackson依赖

<dependency>
            <groupId>com.fasterxml.jackson.dataformat</groupId>
            <artifactId>jackson-dataformat-xml</artifactId>
        </dependency>

image.gif

配置消息转换器(在publisher和consumer两个服务的启动类中添加一个Bean):

@Bean
    public MessageConverter jacksonMessageConvertor(){
        return new Jackson2JsonMessageConverter();
    }

image.gif

2.运行结果

重启项目,运行测试类,并在RabbitMQ管理控制台查看消息:


在consumer服务中新建一个类实现消息接收

@RabbitListener(queues = "object.queue")
    public void listenObject(Map<String, Object> msg) throws InterruptedException {
        System.out.println("object.queue:" + msg);
    }

image.gif

重启项目查看结果



总结

RabbitMQ是一个开源的消息队列软件,旨在提供可靠的消息传递和消息队列功能。本文主要介绍了RabbitMQ默认转换器、JSON转换器及其案例等内容,希望对大家有所帮助。

相关实践学习
消息队列RocketMQ版:基础消息收发功能体验
本实验场景介绍消息队列RocketMQ版的基础消息收发功能,涵盖实例创建、Topic、Group资源创建以及消息收发体验等基础功能模块。
消息队列 MNS 入门课程
1、消息队列MNS简介 本节课介绍消息队列的MNS的基础概念 2、消息队列MNS特性 本节课介绍消息队列的MNS的主要特性 3、MNS的最佳实践及场景应用 本节课介绍消息队列的MNS的最佳实践及场景应用案例 4、手把手系列:消息队列MNS实操讲 本节课介绍消息队列的MNS的实际操作演示 5、动手实验:基于MNS,0基础轻松构建 Web Client 本节课带您一起基于MNS,0基础轻松构建 Web Client
相关文章
|
7月前
|
消息中间件 数据可视化 Go
Rabbitmq 搭建使用案例 [附源码]
Rabbitmq 搭建使用案例 [附源码]
58 0
|
3月前
|
消息中间件 Java Kafka
RabbitMQ 入门
RabbitMQ 入门
|
6月前
|
消息中间件 新零售 弹性计算
云消息队列 RabbitMQ 版入门训练营,解锁对比开源优势与零基础实战
欢迎加入「云消息队列 RabbitMQ 版入门训练营」。
184 18
|
5月前
|
消息中间件 存储 Java
分享一下rocketmq入门小知识
分享一下rocketmq入门小知识
65 0
分享一下rocketmq入门小知识
|
5月前
|
网络协议 物联网 测试技术
App Inventor 2 MQTT拓展入门(保姆级教程)
本文演示的是App和一个测试客户端进行消息交互的案例,实际应用中,我们的测试客户端可以看着是任意的、支持MQTT协议的硬件,通过订阅及发布消息,联网硬件与我们的App进行双向数据通信,以实现万物互联的智能控制效果。
284 2
|
5月前
|
消息中间件 Arthas Java
RocketMQ—一次连接namesvr失败的案例分析
项目组在使用RocketMQ时遇到Consumer连接Name Server失败的问题,异常显示连接特定地址失败。通过Arthas工具逐步分析代码执行路径,定位到创建Channel返回空值导致异常。进一步跟踪发现,问题源于Netty组件在初始化`ByteBufAllocator`时出现错误。分析依赖后确认存在Netty版本冲突。解决方法为排除冲突的Netty包,仅保留兼容版本。
381 0
RocketMQ—一次连接namesvr失败的案例分析
EMQ
|
8月前
|
安全 网络性能优化
MQTT 5.0 报文(Packets)入门指南
MQTT 控制报文是 MQTT 数据传输的最小单元。MQTT 客户端和服务端通过交换控制报文来完成它们的工作,比如订阅主题和发布消息。
EMQ
742 14
MQTT 5.0 报文(Packets)入门指南
|
7月前
|
数据采集 监控 物联网
MQTT协议在智能制造中的应用案例与效益分析
【6月更文挑战第8天】MQTT协议在智能制造中的应用案例与效益分析
222 1
|
7月前
|
消息中间件 存储 Kafka
01.RabbitMQ入门
01.RabbitMQ入门
67 0
|
7月前
|
消息中间件 存储 前端开发
RabbitMQ在Java中的完美实现:从入门到精通
本文由木头左介绍如何在Java项目中使用RabbitMQ。RabbitMQ是开源的AMQP实现,支持多种客户端,适合分布式系统中的消息传递。首先需安装Erlang和RabbitMQ,接着在Java项目中添加RabbitMQ客户端库依赖。通过创建连接工厂和连接,建立与RabbitMQ的通信,并展示了创建连接和通道的代码示例。