使用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);
    }
}

效果

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

相关推荐
代码or搬砖32 分钟前
JVM垃圾回收算法
jvm·算法
Benny的老巢36 分钟前
Chrome 缓存迁移教程:5种方法解决 C 盘空间不足问题(2026年最新)
c语言·chrome·缓存
oMcLin1 小时前
如何在 RHEL 8 上搭建高效的 Redis 集群,支持跨地域的数据同步与低延迟缓存访问?
数据库·redis·缓存
报错小能手1 小时前
线程池学习(四)实现缓存线程池(Cached ThreadPool)
java·学习·缓存
qualifying1 小时前
JavaEE——多线程(5)
java·jvm·java-ee
山沐与山1 小时前
【Redis】双重判定锁详解:缓存击穿的终极解决方案
java·redis·缓存
咖丨喱1 小时前
【解析并缓存 P2P_ATTR_DEVICE_INFO】
缓存·asp.net·p2p
2501_941865633 小时前
从事件驱动到异步架构的互联网工程语法构建与多语言实践分享
java·开发语言·jvm
她和夏天一样热11 小时前
【观后感】Java线程池实现原理及其在美团业务中的实践
java·开发语言·jvm
C_心欲无痕11 小时前
浏览器缓存: IndexDB
前端·数据库·缓存·oracle