ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

谷歌开源缓存Guava Cache使用

2021-04-22 21:32:24  阅读:136  来源: 互联网

标签:缓存 Cache List 本地 import Guava com


目录

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;
    }
    

标签:缓存,Cache,List,本地,import,Guava,com
来源: https://www.cnblogs.com/Gen2021/p/14691585.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有