码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 微服务框架 SpringCloud微服务架构 16 SpringAMQP 16.9 消息转换器


    微服务框架

    【SpringCloud+RabbitMQ+Docker+Redis+搜索+分布式,系统详解springcloud微服务技术栈课程|黑马程序员Java微服务】

    SpringCloud微服务架构

    文章目录

        • 微服务框架
        • SpringCloud微服务架构
        • 16 SpringAMQP
          • 16.9 消息转换器
            • 16.9.1 一个案例
            • 16.9.2 消息转换器
            • 16.9.3 总结

    16 SpringAMQP

    16.9 消息转换器
    16.9.1 一个案例

    案例:测试发送Object类型消息

    说明:在SpringAMQP的发送方法中,接收消息的类型是Object,也就是说我们可以发送任意对象类型的消息,SpringAMQP会帮我们序列化为字节后发送。

    我们在consumer中利用@Bean声明一个队列:

    @Bean
    public Queue objectQueue(){
        return new Queue("object.queue");
    }
    
    • 1
    • 2
    • 3
    • 4

    现在直接重启 consumer 服务

    在这里插入图片描述

    OK,重启成功,直接查看RabbitMQ 控制台

    在这里插入图片描述

    可以看到 object.queue 队列已经生成了

    在publisher中发送消息以测试:

    @Test
    public void testSendObjectQueue(){
    
        Map<String, Object> msg = new HashMap<>();
        msg.put("name","DingJiaxiong");
        msg.put("age",22);
        rabbitTemplate.convertAndSend("object.queue",msg);
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8

    直接运行

    在这里插入图片描述

    绿了, 消息发送成功 了

    看看控制台

    在这里插入图片描述

    点进去查看详细信息

    在这里插入图片描述

    从内容类型可以看到, application/x-java-serialized-object 进行了java 序列化

    【如何解决?】

    16.9.2 消息转换器

    Spring的对消息对象的处理是由org.springframework.amqp.support.converter.MessageConverter来处理的。而默认实现是SimpleMessageConverter,基于JDK的ObjectOutputStream完成序列化。

    如果要修改只需要定义一个MessageConverter 类型的Bean即可。推荐用JSON方式序列化,步骤如下:

    1. 在publisher服务引入依赖【其实干脆可以直接放到父工程】
    <dependency>
        <groupId>com.fasterxml.jackson.coregroupId>
        <artifactId>jackson-databindartifactId>
    dependency>
    
    • 1
    • 2
    • 3
    • 4

    记得刷一下

    在这里插入图片描述

    1. 在publisher服务声明MessageConverter:

    直接加 publisher 服务的启动类中加bean

    package cn.itcast.mq;
    
    import org.springframework.amqp.support.converter.Jackson2JsonMessageConverter;
    import org.springframework.amqp.support.converter.MessageConverter;
    import org.springframework.boot.SpringApplication;
    import org.springframework.boot.autoconfigure.SpringBootApplication;
    import org.springframework.context.annotation.Bean;
    
    @SpringBootApplication
    public class PublisherApplication {
        public static void main(String[] args) {
            SpringApplication.run(PublisherApplication.class);
        }
    
        @Bean
        public MessageConverter messageConverter(){
    
            return new Jackson2JsonMessageConverter();
        }
    
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21

    OK

    先到控制台把之前 那个消息清理掉

    在这里插入图片描述

    在这里插入图片描述

    OK,这样消息就都没了

    直接重新运行我们之前的测试

    在这里插入图片描述

    OK,发送成功,直接查看控制台

    在这里插入图片描述

    妙啊

    【现在发送json 是完成了,接收json 该怎么做?】

    在consumer服务引入Jackson依赖:

    【依赖就不用导了,因为我们刚刚已经把依赖放到了父工程,所以每个儿子都有】

    在consumer服务定义MessageConverter:

    在这里插入图片描述

    直接贴过来就行了,不用改

    然后定义一个消费者,监听object.queue队列并消费消息:

    @RabbitListener(queues = "object.queue")
    public void listenObjectQueue(Map<String, Object> msg) {
        System.out.println("接收到object.queue的消息:" + msg);
    }
    
    • 1
    • 2
    • 3
    • 4

    在这里插入图片描述

    OK,直接重启消费者服务

    在这里插入图片描述

    效果很明显,直接就把上次我们发那个消费掉了【这就是消息转换器】

    在这里插入图片描述

    在这里插入图片描述

    16.9.3 总结

    SpringAMQP中消息的序列化和反序列化是怎么实现的?

    • 利用MessageConverter实现的,默认是JDK的序列化
    • 注意发送方与接收方必须使用相同的MessageConverter
  • 相关阅读:
    【计算机网络】传输层(四)—— TCP 可靠传输、流量控制、拥塞控制
    Go:命令行参数解析包 flag 简介
    springcloud第4季 使用resilience4j实现服务流量治理
    【离线/并查集】CF1213 G
    抖音上怎么挂小程序?制作小程序挂载抖音视频
    开利网络携手南京同仁堂开启“链企来”大健康企业专场沙龙会
    二.go语言条件与循环
    abp(net core)+easyui+efcore实现仓储管理系统——模块管理升级(六十)
    【前端修炼场】 — 这些标签你学会了么?快速拿下 “hr”
    菊风入选2022·爱分析保险科技厂商报告,为保险行业数智化转型赋能
  • 原文地址:https://blog.csdn.net/weixin_44226181/article/details/128181121
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号