谷粒商城实战(020 RabbitMQ-消息确认)

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

总时长 104:45:00 共408P

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


消息确认


生产者 publishers

消费者 consumers

设置配置类

调用api

控制台

抵达brocker 代理

新版本ReturnCallback已弃用,可以这么写:rabbitTemplate.setReturnsCallback(System.out::println);

有这个方法,没过时啊,只是封装到了ReturnedMessage

投递到队列失败时才会回调



消费端确认机制

自动ack(危险,容易丢失数据)

手动dck(推荐开启)

如果通道中断(宕机等),消息会变成ready状态,通道打开为ack的时候会进入 unacked状态


进行ack 然后不是批量的签收 只ack自己

这里无法模拟真正宕机 所以其他的方法也运行了

IDEA还是会把进程走完,应该用 kill -9 pid 才能模拟服务器宕机

要想模拟真实的宕机,用netstat找出9000端口的进程,用taskkill杀掉进程

basicNack()的三个参数 id,是否批量拒绝,是否重新入队

重新入队后 还会进行投递,所以这里的数据变为了0


接收方法:开启手工模式

这里等订单模块需要的时候再进行详解


相关推荐
日月云棠14 小时前
各版本JDK对比:JDK 25 特性详解
java
用户83071968408214 小时前
Spring Boot 项目中日期处理的最佳实践
java·spring boot
JavaGuide15 小时前
Claude Opus 4.6 真的用不起了!我换成了国产 M2.5,实测真香!!
java·spring·ai·claude code
IT探险家15 小时前
Java 基本数据类型:8 种原始类型 + 数组 + 6 个新手必踩的坑
java
花花无缺15 小时前
搞懂new 关键字(构造函数)和 .builder() 模式(建造者模式)创建对象
java
用户9083246027315 小时前
Spring Boot + MyBatis-Plus 多租户实战:从数据隔离到权限控制的完整方案
java·后端
桦说编程16 小时前
实战分析 ConcurrentHashMap.computeIfAbsent 的锁冲突问题
java·后端·性能优化
初次攀爬者16 小时前
ZooKeeper 实现分布式锁的两种方式
分布式·后端·zookeeper
玹外之音17 小时前
Spring AI MCP 实战:将你的服务升级为 AI 可调用的智能工具
spring·ai编程
来一斤小鲜肉18 小时前
Spring AI入门:第一个AI应用跑起来
spring·ai编程