spring boot 中缓存使用 @Cacheable redis缓存不生效的

@Cacheable 注解在对象内部调用不会生效

代码示例:
ProductServiceImpl.java

  public List<ProductInfoVO> getProductList(CommonRequest<ProductInfoDTO> reqest) {
   // @Cacheable失效,不会走缓存的
    return  this.findProductInfoList(reqest);
  }
  
  @Cacheable(cacheNames = "productInfos",cacheManager="jfinetchRedisCacheManager", key = "'jbs:product:list:'.concat(#reqest.getChannelCode())")
  public List<ProductInfoVO> findProductInfoList(CommonRequest<ProductInfoDTO> reqest){
      List<ProductInfoVO> redisList = productService.findList(reqest);
      redisList = redisList.stream().filter(it -> ProductStatusEnum.OPEN.getCode().equals(it.getStatus())).collect(Collectors.toList());

      return redisList;
  }
  

此时getProductList 调用findProductInfoList缓存注解@Cacheable 是不会生效的

原因:
Spring 缓存注解是基于Spring AOP切面,必须走代理才能生效,同类调用或者子类调用父类带有缓存注解的方法时属于内部调用,没有走代理,所以注解不生效。
解决方法: 将方法抽离到一个独立类中,代码示例如下:
ProductServiceImpl.java

 @Autowired
 private ProductBiz productBiz;
    
 public List<ProductInfoVO> getProductList(CommonRequest<ProductInfoDTO> reqest) {
	//第二次调用走缓存
   return  productBiz.findProductInfoList(reqest);
 }

ProductBiz .java

@Service
@Slf4j
public class ProductBiz {

    @Autowired
    private IProductService productService;

    @Cacheable(cacheNames = "productInfos",cacheManager="jfinetchRedisCacheManager", key = "'jbs:product:list:'.concat(#reqest.getChannelCode())")
    public List<ProductInfoVO> findProductInfoList(CommonRequest<ProductInfoDTO> reqest){
        List<ProductInfoVO> redisList = productService.findList(reqest);
        redisList = redisList.stream().filter(it -> ProductStatusEnum.OPEN.getCode().equals(it.getStatus())).collect(Collectors.toList());

        return redisList;
    }

}
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章