谷粒商城实战(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


接收方法:开启手工模式

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


相关推荐
pengyu9 分钟前
【Java设计原则与模式之系统化精讲:壹】 | 编程世界的道与术(实战指导篇)
java·后端·设计模式
日月星辰Ace12 分钟前
JVM 垃圾回收简介
java
掉头发的王富贵14 分钟前
Arthas神器入门:动态调试Java应用,轻松搞定生产环境Bug!
java·后端·debug
Java陈序员19 分钟前
再见 Navicat!一款开源的 Web 数据库管理工具!
java·react.js·docker
zhuhit23 分钟前
FASTDDS的安全设计
分布式·机器人·嵌入式
暗影八度26 分钟前
Spark流水线+Gravitino+Marquez数据血缘采集
大数据·分布式·spark
apprentice30 分钟前
Spring AI使用MCP的简单流程
后端·spring
知其然亦知其所以然36 分钟前
RAG 结果太水?用 RRF + Reranker 重排,效果翻倍提升!
java·后端·llm
SimonKing38 分钟前
吊打面试官系列:Spring为什么不推荐使用字段依赖注入?
java·后端·架构
魔镜魔镜_谁是世界上最漂亮的小仙女44 分钟前
java-集合
java·后端·程序员