Spring三级缓存问题?

使用三级缓存而不是二级缓存的原因是什么?
有的博客说是避免出现多个代理对象
还有的说是为了减少Bean对象引用的提前暴露
大家认为是为啥? #Java#
全部评论
三级缓存主要为了代理模式,做一个工厂,然后确定是否需要经过代理,然后将半成品(非代理/代理增强)放入二级缓存
3 回复 分享
发布于 2023-12-31 14:05 浙江
应该是和bean的生命周期相关,好像最开始就是两级缓存,后面加入了动态代理,改成了三级缓存,我在别的地方看到过帖子
2 回复 分享
发布于 2024-01-07 00:48 陕西
解决循环依赖吧
2 回复 分享
发布于 2023-12-31 16:03 陕西
网上大部分说的什么第三级关于aop都是不对的,其本质原因是如果只有两级,那么每次调用lambda表达式都是创建一个新的对象,因为在一个完整的依赖流程没有结束前,每次调用都是返回一个新的bean。首先明确一点一个完整的bean是需要实例化+初始化都完成了才会被放入一级缓存,那么比如a依赖b和c,b依赖a,c依赖a,那么执行流程是实例化a,发现需要b,实例化b,发现需要a,去一级缓存找到a没找到,去二级缓存找a没找到,去三级缓存创建a,半成品a被保存到二级缓存(由于a还有c需要创建,所以a暂时只会留在二级缓存,不会去一级缓存),b里面a使用的就是半成品对象,b被放入一级缓存,(现在b的流程结束了,返回对象a),发现a还是需要c,实例化c,发现c也需要a,去一级缓存里找没找到a,去二级缓存里面找,找到半成品a了,直接拿来用。看到了关键了吗?如果没有二级缓存,那在这里,c同样会去调用lambda表达式弄一个新的a出来,这也破坏了单例了,彻底错了
1 回复 分享
发布于 2024-01-21 18:56 上海
我觉得是保证bean的"单例属性",一个beanname对应一个bean,如果A有两个循环依赖,然后正好还进行了aop,不用三级缓存就会存两个代理对象。
1 回复 分享
发布于 2024-01-10 19:47 广西
二级缓存装的是半成品bean,考虑不用第三级只用前两级的情形:a实例化,放入二级缓存,属性填充 此时发现a依赖新bean b,去做bean b的创建,b实例化,放入二级缓存,属性填充 此时发现b依赖a 去二级缓存找a 命中了 给b装配上a。 在不考虑代理的情形,这是没问题。但如果a用了aop 真正该用的是a的aop增强的代理对象,但前面的逻辑b装配上的却是原始a! 第三级缓存我理解是去存了beanName,原始bean实例以及真正所需bean对象的创建逻辑。aop的话应该是用了个beanpostprocessor
1 回复 分享
发布于 2023-12-31 01:30 上海
应该是为了在没有出现循环依赖的情况下延迟代理对象的生成。
点赞 回复 分享
发布于 2024-04-11 14:39 湖北
打破循环依赖
点赞 回复 分享
发布于 2024-02-14 18:06 湖南
m
点赞 回复 分享
发布于 2024-02-04 20:58 广东
我觉得是本来aop代理是要在初始化之后生成的,但是如果没有三级缓存那你就必须在初始化之前给所有bean生成代理对象,这违背了spring结合aop的一个设计
点赞 回复 分享
发布于 2024-01-26 14:17 陕西
m
点赞 回复 分享
发布于 2024-01-25 00:55 广东
使用三级不是二级的主要目的是为了解决循环依赖问题中,在装配时产生动态代理对象和初始对象
点赞 回复 分享
发布于 2024-01-10 19:30 海南
没有第二级缓存,无法判断是否存在循环依赖。
点赞 回复 分享
发布于 2023-12-31 01:25 浙江

相关推荐

2025-12-05 19:10
门头沟学院 Java
1.描述过往项目中印象最深的问题及解决过程2.秒杀活动中如何评估数据库支持的最大并发量?3.提到Redis缓存库存,如何评估数据库与Redis的并发支持能力(如QPS值)?4.磁盘读取数据时,如何通过磁道地址定位数据?磁道寻址的时间成本如何?5.磁盘旋转一圈的时间大约是多少?6.为什么选择Redis而非本地内存实现缓存?7.Redis的高可用性具体如何体现?8.主从模式下,主库与从库如何同步数据?同步延迟如何处理?9.主备模式下,从库读取数据可能出现脏读,如何平衡高可用性与数据一致性?10.秒杀场景中使用Redis的持久化机制的必要性?11.秒杀中使用的什么数据结构?我不会就说哈希脑子也是抽了12.为什么在秒杀中使用哈希数据结构?具体解决了什么问题?13.MyBatis与Redis结合使用的场景14.MyBatis缓存是否了解?是否了解MyBatis的二级缓存机制?如何与Redis集成实现分布式缓存?15.消息队列的持久化配置是否确认过?默认存储位置是内存还是磁盘?16.如何理解跨域问题17.基于TCP协议的网络通信中,如何实现超时控制?主调侧如何检测超时?18.描述DNS寻址流程19.DNS缓存可能导致脏数据,如何更新域名解析记录(如A记录变更后的全网同步)20.TCP协议中,超时重传机制的具体实现(如重传计时器、ACK确认)21.MySQL的查询缓存(Query Cache)机制是否了解?与Redis缓存的区别?22.对比Redis与本地内存的差异,除持久化外还有哪些选择依据?23.Redis的AOF和RDB持久化机制的区别?如何选择适用场景?24.主备模式下,备节点是否支持读操作?默认配置下的读写策略是什么?25.项目中使用的消息队列是否考虑过数据丢失风险?如何保证可靠性?
点赞 评论 收藏
分享
评论
5
18
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务