【Redis 开发】多级缓存,本地进程缓存Caffeine

多级缓存

多级缓存

Redis处理并发的能力是非常强大的,但是tomcat的支持并发的能力跟不上Redis的性能,导致整体性能的下降

Redis缓存失效时,会对数据库产生冲击,之间再无屏障

为了应对上述问题,我们采用多级缓存,就是在请求处理的每个环节分别添加缓存,减轻tomcat的压力,提升性能

  1. 对于一些静态资源的请求,可以放在浏览器客户端的缓存上
  2. nginx也可以编辑代码进行缓存
  3. 第三步直接由nginx转向Redis缓存进行查询减轻tomcat的压力
  4. 在tomcat服务器上也设置缓存不必访问数据库提高性能

本地进程缓存Caffeine

比如:HashMap,GuavaCache,Caffeine

优点:读取本地内存,没有网络开销,速度更快

缺点:存储容量有限,可靠性较低,无法共享

场景:性能要求较高,缓存数据量较小

我们这里使用Caffeine

Caffeine是一个基于java8开发的,提供了近乎最佳命中率的高性能本地缓存库

地址:https://github.com/ben-manes/caffeine

  • 快速使用Caffeine
java 复制代码
//创建缓存对象
Cache<String,String> cache=Caffeine.newBuilder().build();
//存数据
cache.put(key,value);
//取数据
String gf=cache.getIfPresent(key);//这种形式不是常用的这里如果缓存查不到就返回null
//取数据-常用,这里如果缓存查不到,就使用第二个参数的方法参数取数据库中进行查找
String gf=cache.get(key,key->{
   //执行查询数据库的业务逻辑
   return 返回数据
})

Caffeine三种缓存驱逐策略

  1. 基于容量,设置缓存的数量上限
java 复制代码
Cache<String,String> cache=Caffeine.newBuilder()
                           .maximumSize(1) //设置缓存大小上限
                           .build();
  1. 基于时间,设置缓存的有效时间
java 复制代码
Cache<String,String> cache=Caffeine.newBuilder()            
                            .expireAfterWrite(Duration.ofSeconds(10))//设置缓存大小上限
                            .build();
  1. 基于引用:设置缓存为软引用或弱引用,利用GC来回收缓存数据,性能较差,不建议使用

默认情况下,当一个元素过期的时候,Caffeine不会立即将其清理或删除,而是当再一次读或写操作后,或者在空闲时间完成对失效数据的驱逐

相关推荐
yeshihouhou6 小时前
redis 单机安装(linux)
数据库·redis·缓存
哈哈哈笑什么6 小时前
多级缓存框架(Redis + Caffeine)完整指南
redis·后端
洞窝技术6 小时前
Redis 4.0 升级至 5.0 实施手册
java·redis
fruge6 小时前
MateChat + DevUI + DeepSeek:教育智能答疑助手改造实践
数据库
LeeZhao@6 小时前
【狂飙全模态】狂飙AGI-智能答疑助手
数据库·人工智能·redis·语言模型·aigc·agi
('-')7 小时前
《从根上理解MySQL是怎样运行的》第二十章笔记
数据库·笔记·mysql
济南壹软网络科技有限公司7 小时前
挑战全球高并发:壹软科技2025新版盲盒源码的“国际合规与弹性架构”解析
数据库·php·uniapp·盲盒源码
i***11867 小时前
Windows环境下安装Redis并设置Redis开机自启
数据库·windows·redis
瀚高PG实验室7 小时前
Oracle或DM(达梦)时间戳之间的差值SQL迁移到瀚高数据库
数据库·sql·oracle·瀚高数据库