使用Caffeine做JVM缓存,提升字典类查询性能

业务场景

对于字典值,一般只存code,名称则查询时去查字典,返回给前端展示。那么就会存在jvm中多次调用字典查询的问题,为了提高性能,对字典进行jvm缓存。
示例代码

  1. Caffeine创建缓存,有效期为5分钟,这个视业务情况而定,看实时性要求。每次查询,可保存5分钟
  2. 编写查询接口,此处会实际调接口,对应接口还可做一层redis缓存,避免直接打到数据库
  3. 实用方法convertDict,通过loadingCache.get查询本地缓存,无数据,则调接口
java 复制代码
@Slf4j
public class DictUtil {
    private static final LoadingCache<String, Map<String, String>> loadingCache = Caffeine.newBuilder().expireAfterWrite(Duration.ofMinutes(5)).build(DictUtil::queryDictAll);
    /**
     * 查询字典  缓存本地  避免多次查询
     */
    private static Map<String, String> queryDictAll(String key) {
        FeignUtils feignUtil = SpringUtil.getBean("feignUtils", FeignUtils.class);
        Map<String, String> allDict = feignUtil.getDictCodeValueMapName(null, key);
        if (CollectionUtil.isNotEmpty(allDict)) {
            return allDict;
        }
        return Collections.emptyMap();
    }
    /**
     * @description: 通过 字典编码和值 获取字典值  比如 caliber 25 得到 DN25
     * @param: [dicType, dictCode]  dicType 推荐使用 DictConstants
     * @return: java.lang.String
     **/
    public static String convertDict(String dicType, String dictCode) {
        if (StringUtils.isBlank(dictCode) || StringUtils.isBlank(dicType)) {
            return null;
        }
        Map<String, String> dictMap = loadingCache.get(dicType);
        if (Objects.isNull(dictMap) || dictMap.size() == 0) {
            return null;
        }
        return dictMap.get(dictCode);
    }
}

效果

避免了频繁调接口查询字典

相关推荐
运维小文31 分钟前
服务器硬件介绍
运维·服务器·计算机网络·缓存·硬件架构
日里安1 小时前
8. 基于 Redis 实现限流
数据库·redis·缓存
王佑辉1 小时前
【jvm】如何判断一个对象是否可以回收
jvm
jerry6097 小时前
7天用Go从零实现分布式缓存GeeCache(改进)(未完待续)
分布式·缓存·golang
看山还是山,看水还是。11 小时前
Redis 配置
运维·数据库·redis·安全·缓存·测试覆盖率
谷新龙00111 小时前
Redis运行时的10大重要指标
数据库·redis·缓存
精进攻城狮@11 小时前
Redis缓存雪崩、缓存击穿、缓存穿透
数据库·redis·缓存
渗透测试老鸟-九青11 小时前
通过投毒Bingbot索引挖掘必应中的存储型XSS
服务器·前端·javascript·安全·web安全·缓存·xss
白总Server12 小时前
JVM解说
网络·jvm·物联网·安全·web安全·架构·数据库架构
向阳121812 小时前
JVM 进阶:深入理解与高级调优
java·jvm