今天碰见了一个BUG,两个系统同使用一个数据库,两个系统都采用的SSH框架,其中一个系统更新了数据库后,另一个系统得5分钟后才能取得更新的数据,肿么回事呢?
仔细查了查,原来是hibernate缓存的问题,众所周知,hibernate是采取二级缓存的策略,第一是session级别的缓存,二是sessionfactory级别的缓存,并且默认二级缓存是打开的。(使用缓存需设置配置hibernate.cache.use_query_cache=true)读取数据的时候,Hibernate将第一次读取的内容放到了缓存中,若此时有别的应用修改了数据库中的数据,程序再次读取的时候,内容是从缓存中直接获取,先从一级缓存中读,若没有则从二级缓存中读取,则读取的数据为过时的数据。
采取的应对措施为:
1.session.clear(),先清除一级缓存
2.createSQLQuery创建的SQLQuery对象query中设置query.setCacheMode(CacheMode.IGNORE);
设置成CacheMode.IGNORE模式,在读取数据的时候,不和二级缓存交换数据,直接读取数据库。
这样数据库更新后hibernate缓存就会实时更新
本文介绍了一个关于两个系统共用同一数据库时遇到的数据更新延迟问题,深入分析发现这是由于Hibernate二级缓存造成。文章提供了两种解决方案:一是清除Session缓存;二是通过设置SQLQuery对象的缓存模式为IGNORE,确保直接从数据库读取最新数据。
484

被折叠的 条评论
为什么被折叠?



