【Redis】缓存穿透、缓存击穿、缓存雪崩产生原因及解决方案

一. 本文对Redis中[缓存穿透]、[缓存击穿]、[缓存雪崩]三种现象产生原因、解决方法进行说明

二. 缓存穿透

1. 原因

缓存不存在或已过期,请求直接打到数据库层

2. 解决方法

  1. 缓存永不失效
  2. 通过设置无过期时间的缓存
  3. 定时任务或异步线程定期更新缓存
  4. 发现缓存即将过期时延长过期时间(过期时间放在缓存中)
  1. 利用互斥锁保证同一时刻只有一个请求可以穿过不存在的缓存直接查数据库,其它请求阻塞,直到拿到锁,再从缓存中获取数据。但使用互斥锁会导致系统吞吐量下降
static Object lockObj = new Object();

synchronized (lockObj) {

    value = redis.get(key);
    if (StringUtils.isNotBlank(value)) {

        return value;
    }

    redis.set(key, value, time);

    return value;
}

三. 缓存击穿

1. 原因

缓存不存在或已过期,数据库也不存在数据

2. 解决方法

  1. 数据库不存在数据时,使用一个默认值回写缓存
  2. 布隆过滤器
  3. 互斥锁

四. 缓存雪崩

1. 原因

同一时刻大量缓存失效

2. 解决方法

  1. 缓存的过期时间尽量均匀分布,避免同时失效
  2. 热点缓存永不过期
  3. 互斥锁

五. 公共解决方法

1. 限流:检测到接口延时较大或异常较多时,进行限流

2. 熔断:检测到接口延时较大或异常较多时,使用降级数据返回或提示用户稍后再试

3. 多级缓存:应将流量尽量分流或过滤,比如从网关、CDN、反向代理层等读取缓存直接返回

Original: https://www.cnblogs.com/gossip/p/14791227.html
Author: 扯
Title: 【Redis】缓存穿透、缓存击穿、缓存雪崩产生原因及解决方案

原创文章受到原创版权保护。转载请注明出处:https://www.johngo689.com/528890/

转载文章受原作者版权保护。转载请注明原作者出处!

(0)

大家都在看

  • Redis设置密码

    设置密码有两种方式。 运行cmd切换到redis根目录,先启动服务端 ><span class="hljs-selector-tag">red…

    Linux 2023年5月28日
    087
  • 网络通信知识地图

    知识地图是一种知识导航系统,并显示不同的知识存储之间重要的动态联系。本篇主要就是从更高的视角将之前的文章的结构思路展现出来。文章结构的思路实际上也是达到架构师程度要掌握的网络通信知…

    Linux 2023年6月14日
    0117
  • 正则表达式测试

    本博客所有文章仅用于学习、研究和交流目的,欢迎非商业性质转载。 博主的文章没有高度、深度和广度,只是凑字数。由于博主的水平不高,不足和错误之处在所难免,希望大家能够批评指出。 博主…

    Linux 2023年6月13日
    091
  • Kubernetes后台数据库etcd:安装部署etcd集群,数据备份与恢复

    服务器版本 docker软件版本 CPU架构 CentOS Linux release 7.4.1708 (Core) Docker version 20.10.12 x86_64…

    Linux 2023年6月7日
    093
  • locate-updatedb命令检索不全

    执行updatedb 命令,用于立刻更新locate 命令所必需的数据库文件,但有些文件可能会在检索过程中被过滤掉。 有时候明明存在的文件,用find 命令都能搜得出来,但用loc…

    Linux 2023年6月13日
    096
  • Android:Jetpack之视图绑定——ViewBinding

    1.Jetpack简介 手机厂商还没卷完Android 12, Android 13就悄然声息地来了,距离Google 2008年9月22日发布Android 1.0,已过去13个…

    Linux 2023年6月13日
    0105
  • 学习一下 SpringCloud (一)– 从单体架构到微服务架构、代码拆分(maven 聚合)

    一、架构演变 1、系统架构、集群、分布式系统 简单理解 (1)什么是系统架构? 【什么是系统架构?】 系统架构 描述了 在应用程序内部,如何根据 业务、技术、灵活性、可扩展性、可维…

    Linux 2023年6月11日
    0101
  • Greenplum数据库基本操作命令大全-完善ing

    Greenplum数据库基本操作命令大全 select * from pg_stat_activity; datid –16388 datname –hfamlgpdbs &a…

    Linux 2023年6月11日
    0106
  • 一键部署服务(shell)

    博客园 :当前访问的博文已被密码保护 请输入阅读密码: Original: https://www.cnblogs.com/Willoneday/p/16534113.htmlAu…

    Linux 2023年6月7日
    095
  • Linux 磁盘挂载

    具体操作是: 1.先对磁盘进行格式化; 挂载磁盘到需要的挂载点; 3.添加分区启动表 1、首先查看系统中磁盘信息 命令为:fdisk -l 2、格式化要挂载的磁盘 格式化命令为:m…

    Linux 2023年6月7日
    093
  • Ruby快速入门

    推荐网站:http://ruby-for-beginners.rubymonstas.org/index.html源码参考:https://gitee.com/komavideo/…

    Linux 2023年6月14日
    0102
  • 001.AD域控简介及使用

    一 AD概述 域(Domain)是Windows网络中独立运行的单位,域之间相互访问则需要建立信任关系。 当一个域与其他域建立了信任关系后,2个域之间不但可以按需要相互进行管理,还…

    Linux 2023年6月7日
    0139
  • 如何实现异步 connect

    写过网络程序的同学,应该都知道 connect 函数,在 socket 开始读写操作之前,先要进行连接,也即 TCP 的三次握手 , 这个过程就是在 connect 函数中完成的,…

    Linux 2023年6月13日
    0116
  • LeetCode_29. 两数相除Divide Two Integers|商的二进制表示与除数的关系

    Problem description Given two integers: dividend and divisor, return dividend/divisor with…

    Linux 2023年6月13日
    079
  • [转]EVE-NG 中使用 SecureCRT 合并tab标签

    在EVE-NG中双击设备使用SecureCRT对设备进行调试连接时,会出现每次连接不同设备时都会打开一个新的SecureCRT窗口,而不是在一个窗口中添加一个新的标签页,这就会导致…

    Linux 2023年6月8日
    0100
  • Linux网络编程基础API

    Linux网络API主要可分为: socket地址API socket基础API 网络信息API socket地址API 两种字节序 大端字节序:整数的高位字节存储在内存的低地址处…

    Linux 2023年6月13日
    076
亲爱的 Coder【最近整理,可免费获取】👉 最新必读书单  | 👏 面试题下载  | 🌎 免费的AI知识星球