redis 雪崩,穿透,击穿及解决方案

news/2024/10/23 9:21:48/

一、缓存雪崩:

  1. 原因:

  缓存雪崩是指在我们设置缓存时大量采用了相同的过期时间,导致缓存在某一时刻同时失效,请求全部转发到DB,DB瞬时压力过重雪崩。

  2. 解决方案:

  1. 将失效时间分散,通过生成随机数使得key的过期时间为随机,防止集体过期。
  2. 使用多级架构,nginx缓存+redis缓存+其他缓存,不同层使用不同缓存,可靠性更强。
  3. 设置缓存标记,如果过期通知其他线程在后台更新实际的key。 这种方法对于性能非常友好,唯一不足的就是构建缓存时候,其余线程(非构建缓存的线程)可能访问的是老数据
  4. 使用锁或者队列的方式
  5. 使用排他锁,其他请求只能等待。

二、缓存穿透:

  1.原因:

缓存穿透是指大量数据查询一个不存在的数据,在流量大时,可能DB就挂掉了,要是有人利用不存在的key频繁攻击我们的应用,这就是漏洞。

  2. 解决方案:

  1. 采用布隆过滤器,将所有可能存在的数据哈希到一个足够大的bitmap中,一个一定不存在的数据会被 这个bitmap拦截掉,从而避免了对底层存储系统的查询压力。
  2. 如果一个查询返回的数据为空(不管是数 据不存在,还是系统故障),仍然把这个空结果进行缓存,但它的过期时间会很短,最长不超过五分钟。

三、缓存击穿:

    1.原因:

热点key过期,大量数据访问过期key

缓存在某个时间点过期的时候,恰好在这个时间点对这个Key有大量的并发请求过来,这些请求发现缓存过期一般都会从后端DB加载数据并回设到缓存,这个时候大并发的请求可能会瞬间把后端DB压垮。

    2. 解决方案:

  1.   提前对热点数据进行设置。对于新闻,某博等热点数据预先设置在redis中
  2.   监控数据,对热点数据实时调整key过期时长。
  3.   使用锁,加锁或者队列的方式保证缓存的单线 程(进程)写,从而避免失效时大量的并发请求落到底层存储系统上。


http://www.ppmy.cn/news/1138554.html

相关文章

3D孪生场景SDK:Viwer 孪生世界

NSDT 编辑器 提供三维场景构建、场景效果设计、场景服务发布全流程工具等,其场景编辑器支持资产管理、灯光设置、骨骼动画等功能;致力于协助资源不足的中小企业及个人快速开发数字孪生场景,帮助企业提高生产力、实现降本增效。 NSDT编辑器简…

C语言 实现 链 显示 效果 查找 修改 删除

显示所有信息 2023年10月1日的描述:今天放假 2023年10月2日的描述:今天有体育 2023年10月3日的描述:今天有数学 2023年10月4日的描述:今天有语文 2023年10月5日的描述:今天有政治 2023年10月6日的描述:今天交学费 2023年10月7日的描述:今天周末 2023年10月8日的描述:今天给家里…

利用freesurfer6进行海马分割的环境配置和步骤,以及获取海马体积

利用freesurfer6进行海马分割的环境配置和步骤 Matlab Runtime 安装1. 运行recon-all:2. 利用 recon-all -s subj -hippocampal-subfields-T1 进行海马分割3. 结束后需要在/$SUBJECTS_DIR/subject/的文件夹/mri路径下输入下面的代码查看分割情况4. 在文件SUBJECTS_D…

C++基础语法——unordered_map和unordered_set

目录 1. unordered系列关联式容器 2.unordered_map ①unordered_map的简介 ②unordered_map的构造 ③unordered_map的容量 ④unordered_map的迭代器 ⑤unordered_map的元素访问 ⑥unordered_map的查询 ⑦unordered_map的修改 ⑧unordered_map的桶操作 3.使用与对比测…

tkinter中如何执行,单击按钮后的线程操作

在Tkinter中,按钮可以绑定一个回调函数来处理点击事件。如果你想在按钮点击时执行一个线程操作,可以在回调函数中创建一个新的线程来处理这个操作。 #我的Python教程 #官方微信公众号:wdPython以下是一个简单的示例代码,演示如何…

条件查询和数据查询

一、后端 1.controller层 package com.like.controller;import com.like.common.CommonDto; import com.like.entity.User; import com.like.service.UserService; import jakarta.annotation.Resource; import org.springframework.web.bind.annotation.GetMapping; import …

【C语言】模拟实现strstr

strstr这个库函数看到这个名字大概率猜不到这是什么函数, 但经过学习就可以很好的认识到这个函数 目录 介绍:模拟实现:思路:代码实现: 介绍: 可以看到此函数是用来寻找一个字符串中是否含有另一个字符串 代…

视频号规则改动,不再支持拍单,传统无货源模式已行不通!

视频号小店批量铺货行不通了,大家好我是派大星,这两天视频号发布了一个公告, 核心信息呢就是10月7号,视频号小店,将无法直接查看消费者的详细下单信息,只能通过电子面单的形式,打单发货。每个店…