如何解决使用 sync=true 的 @Cacheable 方法如何处理异常
我在 Spring Boot 2.0 中使用 @Cacheable 和 EHcache,同步=true。
我知道如果我们设置sync=true,所有线程都会等到一个线程通过执行使用@Cacheable的方法获取要缓存的值。
如果该方法出现异常会怎样?其他线程是一直在等待还是锁被释放了?
解决方法
@Cacheable 注解的想法是你用它来标记 方法返回值将存储在缓存中。
每次 方法被调用,Spring 会在调用后缓存它的返回值 以确保下次执行该方法时使用相同的 参数,可以直接从缓存中获取结果,无需 需要再次执行该方法。 Spring缓存返回值 具有键值对的方法。该值是返回结果 方法。
现在来回答您的问题,让我们先了解什么是同步缓存
同步缓存
在多线程环境中,某些操作可能 同时为同一参数调用(通常在启动时)。经过 默认情况下,缓存抽象不锁定任何东西,同样 值可能会被多次计算,从而达不到缓存的目的。
对于那些特殊情况,您可以使用 sync 属性来指示 底层缓存提供者锁定缓存条目,而值 正在计算中。结果,只有一个线程忙于计算 值,而其他的则被阻止,直到条目在 缓存
sync 属性的唯一目的是只有一个线程会构建缓存,其他线程会消耗缓存。现在如果在方法执行过程中出现异常,这意味着获得锁的线程将永远不会在缓存中设置任何内容并退出,现在下一个线程将有机会获得锁,因为缓存中不会有任何东西,如果在第二个线程的执行异常发生,然后下一个线程将得到它的机会,直到一个线程为相同的参数设置缓存。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。