jvm一级缓存

1、利用JVM缓存。脱离redis。

2、导包,springboot自带此包。如没有可以导:com.google.guava:guava:20.0的包。

3、直接上代码:

java 复制代码
package com.leo.cache;

import com.alibaba.fastjson.JSONObject;
import com.google.common.cache.Cache;
import com.google.common.cache.CacheBuilder;
import lombok.SneakyThrows;
import org.springframework.stereotype.Component;

import javax.annotation.PostConstruct;
import javax.annotation.Resource;
import java.util.List;
import java.util.Map;
import java.util.Objects;
import java.util.concurrent.TimeUnit;


/**
 * @author Leo
 */
@Component
public class JvmLruOneCacheComponent {

    Cache<String, String> allCache;

    @PostConstruct
    public void initCache() {
        allCache = CacheBuilder.newBuilder()
                .weakValues()
                最大容量
                .maximumSize(10L)
                //多少分钟后没有访问的数据会被清除
                .expireAfterAccess(30L, TimeUnit.MINUTES)
                // 设置并发级别为cpu核心数
                .concurrencyLevel(Runtime.getRuntime().availableProcessors() * 2)
                .build();
    }

    public Map<String, String> getCache() {
        return allCache.asMap();
    }


    @SneakyThrows
    public List<StockCrawlingResponseDto> getStockCrawlingList() {
        String key = "xxxxxxx";
        //先获取缓存。没有缓存就从后面的方法获取数据并存入缓存
        String jsonStr = allCache.get(key, () -> JSONObject.toJSONString(xxxxService.getData()));
        return JSONObject.parseArray(jsonStr, xxxdto.class);
    }

    public String getCacheByKey(String key) {
        return allCache.getIfPresent(key);
    }

    public void setCacheByKey(String key, String value) {
        allCache.put(key, value);
    }

    public void deleteAllCache() {
        allCache.invalidateAll();
    }

    public void deleteCache(String key) {
        allCache.invalidate(key);
    }
}
相关推荐
Maiko Star2 小时前
基于Redis ZSet实现多维度题目贡献度排行榜
数据库·redis·缓存
减_简4 小时前
JVM 之 线上诊断神器Arthas【常用命令?如何使用Arthas排查cpu飙高、类加载问题、死锁、慢接口等问题?】
jvm
透明的玻璃杯4 小时前
sqlite数据库连接池
jvm·数据库·sqlite
7ioik4 小时前
jvm性能检测及调优?
jvm
何中应4 小时前
【面试题-4】JVM
java·jvm·后端·面试题
7ioik4 小时前
jvm垃圾回收算法?
jvm·算法
pingcode6 小时前
IDEA清除缓存
缓存·intellij-idea
不会写程序的未来程序员6 小时前
Redis 缓存
数据库·redis·缓存
脸大是真的好~7 小时前
黑马消息队列-rabbitMQ2-生产者重连机制-生产者确认机制-数据持久化-LazyQueue-消费者确认机制-失败重试机制-重试耗尽告警手动处理-
java·缓存·中间件
源代码•宸15 小时前
分布式缓存-GO(分布式算法之一致性哈希、缓存对外服务化)
开发语言·经验分享·分布式·后端·算法·缓存·golang