如何解决事务回滚后,带有 infinispan 的 Hibernate 2LC 持有陈旧的实体
我在 WildFly 23.0.2 服务器(Hibernate 5.3.20、Infinispan 11.0.9)上运行 JEE 应用程序。我有二级缓存的默认设置,这包括 Wildfly 配置(standalone-full.xml)中的区域设置以及 Hibernate 的配置(persistence.xml):
<shared-cache-mode>ENABLE_SELECTIVE</shared-cache-mode>
<property name="hibernate.cache.use_second_level_cache" value="true" />
<cache-container name="hibernate" modules="org.infinispan.hibernate-cache">
<local-cache name="entity">
<heap-memory size="10000"/>
<expiration max-idle="100000"/>
</local-cache>
<local-cache name="local-query">
<heap-memory size="10000"/>
<expiration max-idle="100000"/>
</local-cache>
<local-cache name="timestamps"/>
<local-cache name="pending-puts">
<expiration max-idle="60000"/>
</local-cache>
</cache-container>
我有一个使用乐观锁检测(“版本”属性)和缓存策略“事务”的实体:
<cache usage="transactional" />
<version generated="never" name="version" type="long" />
我有一个由两个事务同时修改的实体的最大集合 (> 2000)。正如预期的那样,当刷新会话时,其中一个事务会遇到 OptimisticLockException。另一个事务完成时没有错误或异常。虽然数据库现在保存实体的更新状态,但二级缓存仍保存旧状态。进一步读取现在将从 2LC 返回旧状态并且无法再更新,因为它有旧版本。
我最近从 WildFly 10 升级,但没有出现此问题。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。