Redis教程(十六):Redis的缓存穿透、缓存击穿、缓存雪崩

缓存穿透

描述

用户需要查询一个数据,例如要查一张ASSET_CODE = '999999'的卡片,查询redis中没有,就直接去请求数据库,数据库中也不存在对应的数据,返回空或错误,当很多用户同时请求并且都没有命中!于是都去请求了持久层的数据库,那么这样会给持久层数据库带来非常大的压力。当高并发或有人利用不存在的Key频繁攻击时,数据库的压力骤增,甚至崩溃,这就是缓存穿透问题。
*

解决方案

  1. 合法请求校验

  2. 缓存空对象

  3. 布隆过滤器

  4. 用户黑名单

缓存击穿

描述

生产上有一个非常热点的key,在不停的扛着大并发,当这个key失效时,一瞬间大量的请求冲到持久层的数据库中,就像在一堵墙上某个点凿开了一个洞!
*

解决方案

  1. 设置热点key永不过期

  2. 加互斥锁,同一时间只有一个线程能访问数据库查询这个key,查到了更新到缓存里,剩下的线程可以正常查询Redis缓存

缓存雪崩

描述

在某一个时间段,Redsi缓存的key大量集中同时过期失效了,所有的请求全部冲到持久层数据库上,导致持久层数据库挂掉!
*

解决方案

  1. 搭建redis集群

  2. 加互斥锁,同一时间只有一个线程能访问数据库查询这个key,查到了更新到缓存里,剩下的线程可以正常查询Redis缓存

  3. 设置不同的过期时间,让缓存失效的时间点尽量均匀

相关推荐
程序员二叉8 小时前
【Redis】 缓存三大问题 + 大Key/热Key 全面解析
数据库·redis·缓存
真实的菜10 小时前
Redis 从入门到精通(二):深入数据结构 —— 从 RedisObject 到 SkipList 的源码级拆解
数据结构·redis·skiplist
就叫_这个吧11 小时前
Java+MySQL+Mybatis+Junit4实现学生信息管理系统
java·mysql·mybatis
闪电悠米12 小时前
黑马点评-秒杀优化-01_async_seckill_idea
java·数据库·ide·redis·分布式·缓存·intellij-idea
必胜刻12 小时前
一个异步生成游戏功能的落地复盘:Redis Stream + WebSocket + 状态补偿
redis·websocket·golang·gin·状态补偿
闪电悠米13 小时前
黑马点评-秒杀优化-02_lua_precheck
开发语言·redis·分布式·缓存·junit·wpf·lua
至天13 小时前
FastAPI 接入 FastAPI-Limiter 以及使用 Redis 进行限流指南
redis·python·fastapi·请求限流
真实的菜13 小时前
Redis 从入门到精通(三):持久化机制 —— RDB 与 AOF 深度解析
数据库·redis·缓存
橙子圆12314 小时前
Redis知识10之缓存
数据库·redis·缓存
情绪总是阴雨天~14 小时前
基于 Docker 的 Milvus + Redis 本地开发环境部署完全指南
redis·docker·milvus