谷粒商城实战(019 RabbitMQ-发送消息)

Java项目《谷粒商城》架构师级Java项目实战,对标阿里P6-P7,全网最强

总时长 104:45:00 共408P

此文章包含第248p-第p261的内容


介绍

MQ的三大特点:流量削峰、应用解耦、异步处理

redis是数据缓存,mq是任务缓存



AMQP的MODEL 第一种是队列的实现 后四种是订阅的实现

网络间传输 万物皆流

概念



一个客户端(消费者)只建立一个链接(长链接)

一连接,多信道


虚拟主机

每个虚拟主机是相互隔离的,一个出问题对其他无影响(沙箱) 相当于又安装了另外一个rabbitmq

也可以开发时一个虚拟主机 上生成环境时一个虚拟主机

长链接的好处: 断开了会实时感知到是否连接到了,不会丢失因为网络断开而导致数据被消费

安装


这里使用docker安装

查看镜像

docker ps 查看正在运行中的容器

bash 复制代码
docker update rabbitmq --restart=always
设置rabbitmq自动启动

docker ps 查看正在运行中的容器 发现已经启动了

如果下载很慢 docker配个阿里镜像加速,用原生的很慢

默认账号密码都是guest

运行状态概览

这里右上方是5秒刷新一次

nodes节点信息


导出配置

交换机

管理设置功能

虚拟主机信息

运行机制


direct,headers是点对点的模式 (headers性能低下 无人用)

fanout,topic是发布订阅的模式

direct直接交换机

fanout广播队列 (全部队列都接收)

topic订阅模式 (可以选择性的发送数据)(部分广播)

可以理解为 私人喇叭,全服大喇叭,频道喇叭

创建交换机

durable持久化 transient非持久化


直连交换机 direct

队列名和路由键可以相同

这里交换机绑定四个队列


Ack 看完了之后消费掉不重新进队 (删除)

扇形交换机fanout


主题交换机 topic


整合Spring

引入了包


这些带@Bean的都是它给容器中放的组件

测试创建交换机

找到rabbit自动配置类(RabbitAutoConfiguration )

发现它的配置信息在RabbitProperties这里类里






测试创建队列



测试绑定



测试发送消息

引入template

发送对象

这里得到的对象是序列化后的对象,所以这个类一定要实现序列化接口 到时候其他程序收到的时候进行反序列化来查看信息


也可以使用json发送数据

实际应用中如果是跨语言了,会发送JSON格式化后的数据,序列化其他语言可能会不支持

源码显示 这里如果容器中有MessageConverter(消息转换器) 就使用我们传入的MessageConverter 进行转换,如果没有定义就会使用序列化的那种

如果没有 用这个默认的SimpleMessageConverter

这里使用的是序列化的方式

写一个to json的

写一个配置类


内容类型 json

接收消息

监听队列

必须有@EnableRabbit才行


windows查看端口占用命令

netstat -ano |findstr 9000 这里是ano跟linux的anp不太一样

查看进程号





通道信息

模拟多个服务消费消息队列信息

这里复制运行配置信息 然后改端口号

发送十条消息



逐步接收的消息


注解放在类上 然后可以使用方法的重载 来进行多种不同类型的数据 方法上要加@RabbitHandler



相关推荐
愿你天黑有灯下雨有伞28 分钟前
告别复杂配置!Spring Boot优雅集成百度OCR的终极方案
spring boot·百度·ocr
我命由我123452 小时前
Kotlin 数据容器 - List(List 概述、创建 List、List 核心特性、List 元素访问、List 遍历)
java·开发语言·jvm·windows·java-ee·kotlin·list
武子康4 小时前
Java-80 深入浅出 RPC Dubbo 动态服务降级:从雪崩防护到配置中心秒级生效
java·分布式·后端·spring·微服务·rpc·dubbo
YuTaoShao7 小时前
【LeetCode 热题 100】131. 分割回文串——回溯
java·算法·leetcode·深度优先
源码_V_saaskw7 小时前
JAVA图文短视频交友+自营商城系统源码支持小程序+Android+IOS+H5
java·微信小程序·小程序·uni-app·音视频·交友
超浪的晨8 小时前
Java UDP 通信详解:从基础到实战,彻底掌握无连接网络编程
java·开发语言·后端·学习·个人开发
双力臂4048 小时前
Spring Boot 单元测试进阶:JUnit5 + Mock测试与切片测试实战及覆盖率报告生成
java·spring boot·后端·单元测试
心之语歌8 小时前
Spring AI MCP 客户端
人工智能·spring·github
Edingbrugh.南空9 小时前
Aerospike与Redis深度对比:从架构到性能的全方位解析
java·开发语言·spring
QQ_4376643149 小时前
C++11 右值引用 Lambda 表达式
java·开发语言·c++