转载自SpringBoot Redis @Cacheable异常导致服务不可用解决方案_cacheable方法之后抛异常_Destiny_zz的博客-CSDN博客
背景
生产环境中,为了提高吞吐量和 QPS ,常常使用 @Cacheable 注解对较频繁访问的数据用 Redis 进行缓存。起初,服务正常运行,后来随着缓存的数据量和请求并发数的增加,偶现从 Redis 中取数据时会抛出连接超时等异常,导致该次请求中断,影响该次业务。更有甚者,当 Redis 宕机时,由于 @Cacheable 注解的方法并未进行缓存冲突,而是直接抛出异常,会导致依赖这些方法的服务不可用。我们需要Redis服务器出现连接超时等问题时不影响程序的正常运行,即出问题时不抛出异常,可以继续向下执行方法,从数据库/本地缓存中进行数据的读取,提高系统的可用性。
分析
由于我们是通过 @EnableCaching 注解启动缓存的,因此可以先从 @EnableCaching 注解的注释入手。
通过 @EnableCaching 注释可以发现,org.springframework.cache.annotation.CachingConfigurer
是 Spring Cache 的核心配置接口,我们可以通过实现该回调接口来定制化缓存的一些相关操作,但是此时我们需要实现该接口的所有方法。
另外,我们也可以使用继承org.springframework.cache.annotation.CachingConfigurerSupport
的方式来自定义缓存相关策略,这也是官方推荐的一种方式。该类对所有有用的方法提供了一个默认的实现,因此如果我们不需要自定义所有方法的话,只需重写我们想要覆盖的方法即可。