【问题标题】:How are exceptions handled in @Cacheable method that uses sync=true如何在使用 sync=true 的 @Cacheable 方法中处理异常
【发布时间】:2021-03-08 16:50:16
【问题描述】:

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

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

如果该方法中有异常会发生什么?是其他线程一直在等待还是锁被释放了?

【问题讨论】:

    标签: spring-boot ehcache


    【解决方案1】:

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

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

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

    同步缓存

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

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

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

    【讨论】:

      猜你喜欢
      • 2019-05-08
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 2017-01-01
      • 1970-01-01
      • 1970-01-01
      • 2014-04-02
      • 1970-01-01
      相关资源
      最近更新 更多