【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不会立即将其清理或删除,而是当再一次读或写操作后,或者在空闲时间完成对失效数据的驱逐

相关推荐
岁岁种桃花儿4 小时前
MySQL从入门到精通系列:InnoDB记录存储结构
数据库·mysql
jiunian_cn5 小时前
【Redis】hash数据类型相关指令
数据库·redis·哈希算法
冉冰学姐5 小时前
SSM在线影评网站平台82ap4(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面
数据库·ssm框架·在线影评平台·影片分类
知识分享小能手6 小时前
SQL Server 2019入门学习教程,从入门到精通,SQL Server 2019数据库的操作(2)
数据库·学习·sqlserver
踩坑小念7 小时前
秒杀场景下如何处理redis扣除状态不一致问题
数据库·redis·分布式·缓存·秒杀
萧曵 丶8 小时前
MySQL 语句书写顺序与执行顺序对比速记表
数据库·mysql
Wiktok9 小时前
MySQL的常用数据类型
数据库·mysql
曹牧9 小时前
Oracle 表闪回(Flashback Table)
数据库·oracle
J_liaty9 小时前
Redis 超详细入门教程:从零基础到实战精通
数据库·redis·缓存
m0_706653239 小时前
用Python批量处理Excel和CSV文件
jvm·数据库·python