本地缓存LoadingCache

引入依赖

xml 复制代码
 <!-- https://mvnrepository.com/artifact/com.google.guava/guava -->
<dependency>
    <groupId>com.google.guava</groupId>
    <artifactId>guava</artifactId>
    <version>32.1.1-jre</version>
</dependency>

主要代码

效果演示

第一次查询,数据没有放入缓存,查询耗时27574ms。查询完成后将数据放入缓存,缓存key是threadName-2

第二次查询,数据已经在缓存中数据瞬间被拿出来。缓存key是threadName-2

第一次查询name=threadName-3,缓存中没有key为threadName-3,耗时22120ms

第二次查询name=threadName-3,缓存有key为threadName-3,瞬间查出

总结:通过缓存key从本地缓存拿数据时如果缓存中有该key则直接从缓存中取出数据,如果缓存中没有该key则先获取数据并放入缓存中最后将数据返回。

本地缓存常用方法

maximumSize() 最多可放入缓存个数。

如果maximumSize=2,则只能放入两条数据也就是两个key。当我们先后存入key1,key2,key3,此时key1会被回收(移除)。

expireAfterWrite

数据写入后过期,即使有访问(读写)也会过期。如果过期时间是30s,30s后向缓存中写数据会触发removalListener。
expireAfterAccess

某一数据写入后,长时间没有写入或者读取会过期

refreshAfterWrite

数据写入缓存后,10s后再次取数据将不会从缓存中取,而是从数据源头拿数据并重新放入缓存

相关推荐
知我Deja_Vu13 天前
redisCommonHelper.generateCode(“GROUP“),Redis 生成码方法
数据库·redis·缓存
没有bug.的程序员13 天前
电商秒杀系统深度进阶:高并发流量建模、库存零超卖内核与 Redis+MQ 闭环
数据库·redis·缓存·高并发·电商秒杀·流量建模·库存零超卖
troublea13 天前
ThinkPHP3.x高效学习指南
mysql·nginx·缓存
troublea13 天前
ThinkPHP6快速入门指南
数据库·mysql·缓存
Emotional。14 天前
AI Agent 性能优化和成本控制
人工智能·深度学习·机器学习·缓存·性能优化
jnrjian14 天前
Oracle 共享池 库缓存下的 Library Cache Lock
数据库·缓存·oracle
Anastasiozzzz14 天前
阿亮随手记:MySQL移除查询缓存、子查询优化深分页、自增主键溢出、索引失效
数据库·mysql·缓存
難釋懷14 天前
Redis消息队列-基于Stream的消息队列-消费者组
数据库·redis·缓存
難釋懷14 天前
Redis消息队列-基于Stream的消息队列
数据库·redis·缓存
troublea14 天前
Laravel 8.x新特性全解析
数据库·mysql·缓存