【发布时间】:2021-03-08 16:50:16
【问题描述】:
我在 Spring Boot 2.0 中使用 @Cacheable 和 EHcache,同步 = true。
我知道,如果我们设置 sync=true,所有线程都会等待,直到一个线程通过执行使用 @Cacheable 的方法来获取要缓存的值。
如果该方法中有异常会发生什么?是其他线程一直在等待还是锁被释放了?
【问题讨论】:
标签: spring-boot ehcache
我在 Spring Boot 2.0 中使用 @Cacheable 和 EHcache,同步 = true。
我知道,如果我们设置 sync=true,所有线程都会等待,直到一个线程通过执行使用 @Cacheable 的方法来获取要缓存的值。
如果该方法中有异常会发生什么?是其他线程一直在等待还是锁被释放了?
【问题讨论】:
标签: spring-boot ehcache
@Cacheable 注解的想法是你用它来标记 方法返回值将存储在缓存中。
每次 方法被调用,Spring会在调用后缓存它的返回值 以确保下次执行该方法时使用相同的 参数,可以直接从缓存中获取结果,无需 需要再次执行该方法。 Spring缓存返回值 键值对的方法。该值是返回结果 方法。
现在来回答你的问题,让我们首先了解什么是同步缓存
同步缓存
在多线程环境中,某些操作可能是 为相同的参数同时调用(通常在启动时)。经过 默认情况下,缓存抽象不锁定任何东西,同样 value 可能会被计算多次,从而违背了缓存的目的。
对于那些特殊情况,您可以使用 sync 属性 来指示 底层缓存提供程序锁定缓存条目,而值 正在计算。结果,只有一个线程忙于计算 值,而其他的则被阻止,直到条目在 缓存
sync 属性的唯一目的是只有一个线程会构建缓存,其他线程会消耗缓存。现在如果在方法执行过程中出现异常,这意味着获得锁的线程将永远不会在缓存中设置任何内容并退出,现在下一个线程将有机会获得锁,因为缓存中不会有任何东西,如果在第二次线程的执行异常发生,然后下一个线程将有机会,直到一个线程为相同的参数设置缓存。
【讨论】: