使用 sync=true 的 @Cacheable 方法如何处理异常

如何解决使用 sync=true 的 @Cacheable 方法如何处理异常

我在 Spring Boot 2.0 中使用 @Cacheable 和 EHcache,同步=true。

我知道如果我们设置sync=true,所有线程都会等到一个线程通过执行使用@Cacheable的方法获取要缓存的值。

如果该方法出现异常会怎样?其他线程是一直在等待还是锁被释放了?

解决方法

@Cacheable 注解的想法是你用它来标记 方法返回值将存储在缓存中。

每次 方法被调用,Spring 会在调用后缓存它的返回值 以确保下次执行该方法时使用相同的 参数,可以直接从缓存中获取结果,无需 需要再次执行该方法。 Spring缓存返回值 具有键值对的方法。该值是返回结果 方法。

现在来回答您的问题,让我们先了解什么是同步缓存

同步缓存

在多线程环境中,某些操作可能 同时为同一参数调用(通常在启动时)。经过 默认情况下,缓存抽象不锁定任何东西,同样 值可能会被多次计算,从而达不到缓存的目的。

对于那些特殊情况,您可以使用 sync 属性来指示 底层缓存提供者锁定缓存条目,而值 正在计算中。结果,只有一个线程忙于计算 值,而其他的则被阻止,直到条目在 缓存

sync 属性的唯一目的是只有一个线程会构建缓存,其他线程会消耗缓存。现在如果在方法执行过程中出现异常,这意味着获得锁的线程将永远不会在缓存中设置任何内容并退出,现在下一个线程将有机会获得锁,因为缓存中不会有任何东西,如果在第二个线程的执行异常发生,然后下一个线程将得到它的机会,直到一个线程为相同的参数设置缓存。

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其他元素将获得点击?
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。)
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbcDriver发生异常。为什么?
这是用Java进行XML解析的最佳库。
Java的PriorityQueue的内置迭代器不会以任何特定顺序遍历数据结构。为什么?
如何在Java中聆听按键时移动图像。
Java“Program to an interface”。这是什么意思?
Java在半透明框架/面板/组件上重新绘画。
Java“ Class.forName()”和“ Class.forName()。newInstance()”之间有什么区别?
在此环境中不提供编译器。也许是在JRE而不是JDK上运行?
Java用相同的方法在一个类中实现两个接口。哪种接口方法被覆盖?
Java 什么是Runtime.getRuntime()。totalMemory()和freeMemory()?
java.library.path中的java.lang.UnsatisfiedLinkError否*****。dll
JavaFX“位置是必需的。” 即使在同一包装中
Java 导入两个具有相同名称的类。怎么处理?
Java 是否应该在HttpServletResponse.getOutputStream()/。getWriter()上调用.close()?
Java RegEx元字符(。)和普通点?