谷歌开源缓存Guava Cache使用

时间:2021-04-22
本文章向大家介绍谷歌开源缓存Guava Cache使用,主要包括谷歌开源缓存Guava Cache使用使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。

1.分布式缓存和本地缓存简介

  • 什么是缓存
    • 程序经常要调用的对象存在内存中,方便其使用时可以快速调用,不必去数据库或者其他持久化设备中查询,主要是提高性能
    • DNS缓存、前端缓存、代理服务器缓存Nginx、应用程序缓存(本地缓存、分布式缓存)、数据库缓存
  • 分布式缓存
    • 与应用分离的缓存组件或服务,与本地应用隔离一个独立的应用,多个应用可直接的共享缓存
    • 常见的分布式缓存:Redis、Memcached等
  • 本地缓存
    • 和业务一起的缓存,例如mybatis的一级或者二级缓存,本地缓存速度最快,但不能在多个节点共享
    • 常见的本地缓存:mybatis一级缓存二级缓存;框架本身的缓存;Redis本地单机服务;ehcache;guava cache;Caffeine等

2.谷歌开源缓存框架Guava Cache使用

  • 添加依赖

    <!--guava缓存依赖包-->
    <dependency>
        <groupId>com.google.guava</groupId>
        <artifactId>guava</artifactId>
        <version>19.0</version>
    </dependency>
    
  • 封装API

    package com.gen.utils;
    
    import com.google.common.cache.Cache;
    import com.google.common.cache.CacheBuilder;
    import lombok.Data;
    import org.springframework.stereotype.Component;
    
    import java.util.concurrent.TimeUnit;
    
    @Component
    @Data
    public class BaseCache {
    
        private Cache<String, Object> tenMinuteCache = CacheBuilder.newBuilder()
                // 设置缓存初始大小,应合理设置,后续会扩容
                .initialCapacity(10)
                // 最大值
                .maximumSize(100)
                // 并发数设置
                .concurrencyLevel(5)
                // 缓存过期时间:写入后10分钟过期
                .expireAfterWrite(10, TimeUnit.MINUTES)
                // 统计缓存命中率
                .recordStats().build();
    }
    
  • 缓存key管理类

    package com.gen.config;
    
    /**
     * 缓存key管理类
     */
    public class CacheKeyManager {
    
        // 首页轮播图缓存key
        public static final String INDEX_BANNER_KEY = "index:banner";
    }
    
  • ServiceImpl类使用

    @Override
    public List<VideoBanner> listBanner() {
        List<VideoBanner> list = null;
        try {
            Object cacheObj = this.baseCache.getTenMinuteCache().get(CacheKeyManager.INDEX_BANNER_KEY, () -> {
                List<VideoBanner> videoBannerList = this.videoMapper.listBanner();
                System.out.println("数据库查询轮播图列表");
                return videoBannerList;
            });
            if (cacheObj instanceof List) {
                list = (List<VideoBanner>) cacheObj;
            }
        }catch (Exception e){
            e.printStackTrace();
        }
        return list;
    }
    

原文地址:https://www.cnblogs.com/Gen2021/p/14691585.html