redis 缓存穿透,缓存击穿,缓存雪崩

一:什么是缓存

(1)计算机:cpu、内存、磁盘,cpu任何需要的数据都要从内容中读入数据放入cpu,从cup内部添加一个缓存

(2)web开发的每个阶段都可以添加缓存

(3)缓存优缺点(中小型企业数据量不大时没必要使用缓存)

二:添加缓存

缓存作用模型(先从redis查询数据,有则返回客户端,无则从redis查询,查询成功后将数据写入缓存,后返回)

2.1 实例-根据id查询商铺缓存

(1)业务逻辑

(2)代码实现

2.2 缓存更新

解决了修改redis后缓存并不知道还保留旧数据问题

(1)业务场景

(2)操作和修改数据库时需要考虑的问题

三:缓存穿透

3.1 基本概述

(1)定义

(2)解决方案

缓存空对象

布隆过滤器

(3)解决方案

3.2 代码实现

商户查询缓存添加

(1)业务逻辑

(2)代码实现

四:缓存雪崩

(1)定义

(2)产生原因

(3)解决方案

五:缓存击穿

(1)定义

(2)解决方案

互斥锁

同一时刻只有一个线程在作业其它都在等待,导致性能差劲

逻辑过期

不设置TTL

(3)两方案比较

相关推荐
chxii5 分钟前
5java集合框架
java·开发语言
?abc!11 分钟前
缓存(3):本地缓存作用 及 数据一致性 实现策略
缓存
yychen_java1 小时前
R-tree详解
java·算法·r-tree
搞不懂语言的程序员1 小时前
Redis的Pipeline和Lua脚本适用场景是什么?使用时需要注意什么?
数据库·redis·lua
JANYI20181 小时前
嵌入式设计模式基础--C语言的继承封装与多态
java·c语言·设计模式
xrkhy2 小时前
反射, 注解, 动态代理
java
Ten peaches2 小时前
Selenium-Java版(操作元素)
java·selenium·测试工具·html
lyw2056192 小时前
RabbitMQ,Kafka八股(自用笔记)
java
邹诗钰-电子信息工程2 小时前
嵌入式自学第二十一天(5.14)
java·开发语言·算法
有梦想的攻城狮2 小时前
spring中的@MapperScan注解详解
java·后端·spring·mapperscan