当前位置: 首页 > news >正文

黑马点评-Redis的缓存击穿,缓存雪崩,缓存穿透,互斥锁,逻辑过期

文章目录

  • 1.缓存穿透
  • 2.缓存雪崩
  • 3.缓存击穿
    • 3.1 互斥锁
    • 3.2 基于逻辑过期

1.缓存穿透

在这里插入图片描述

解决办法
在这里插入图片描述

写入NULL值到Redis缓存,以后就会命中Redis的控制缓存而不会出现请求直接打到数据库的问题!
代码
在这里插入图片描述
在这里插入图片描述

2.缓存雪崩

这个概念很好理解,雪崩就是无数的小雪花结构突然因为外界传递的巨大能量而受到破坏,因此无数雪花结构崩溃导致雪崩,这里缓存里面的key也是一样的,大量的key同时失效导致大量请求打到数据库,导致数据库崩溃!

在这里插入图片描述

3.缓存击穿

在这里插入图片描述

在这里插入图片描述

3.1 互斥锁

利用到了Redis的setnx指令,这种指令设置的key是只有该key不存在时才会被修改成功,如果该key已经存在,则无法修改该key。利用该特性,如果大量的线程来到获取该key并修改该key为1,那么实际上只有1个key才会被修改成功,并且java中提供了相应的函数提供此功能,如果修改成功,那么返回True,如果修改失败,那么返回false,根据此特性,如果我们使用该函数如果返回False那就是获取互斥锁失败,如果True那就是获取互斥锁成功!接着我们可以直接使其他所有的相关线程Sleep就完事儿了,等到获取互斥锁成功的线程执行完重构缓存的命令完了之后再来访问!原来成功获取锁的线程就直接返回旧的缓存数据即可!这个就是互斥锁原理!
在这里插入图片描述

3.2 基于逻辑过期

逻辑过期的应用场景是对于热点Key的访问,比如商家做活动的时候,系统里面有经常访问到的key,这种key就是热点key。
在这里插入图片描述
逻辑过期给出的解决方案:
在逻辑过期的解决方案里面,热点key的缓存的TTL都是直接设置为-1的,即永久保存在Redis中,但是这样我们如何区分这些个热点key有无过期呢?于是我们设置了expire字段,标记他有无过期,如果当前时间在这个expire之前,那么就是该热点key没过期,直接去做缓存重建,重置热点key的expire(在原来expire过期时间上再次加上30分钟),如果过期了,那就直接返回旧的缓存数据,获取锁完成缓存重建,用线程池里面的线程完成缓存重建!这样无论如何都能保证到热点key永不过期,永远不会说是热点key过期了的瞬间又瞬间来了大量的请求打到后台数据库导致数据库宕机!
一般来说在这套流程里面,缓存都是命中的,如果没命中,只能说明这个key不是热点key,中了就是热点key。因为我们的Redis都是提前缓存好了许多的热点key的,热点key才会命中,冷门key就没命中,因为冷门key不在Redis里面。在这里插入图片描述

在这里插入图片描述

http://www.lryc.cn/news/390402.html

相关文章:

  • 8624 多项式系数累加和
  • 使用 C# 和 OpenXML 读取大型 Excel 文件
  • 【基于R语言群体遗传学】-5-扩展到两个以上等位基因及多基因位点
  • 重采样(上采样或下采样)是什么?
  • AI与Python共舞:如何利用深度学习优化推荐系统?(2)
  • ChatGPT:Java中的对象引用实现方式
  • 云渗透实战手册:云API攻防之云服务端点侦查
  • PHP 爬虫之使用 Curl库抓取淘宝商品列表数据网页的方法
  • Python基础小知识问答系列-可迭代型变量赋值
  • 主流 Canvas 库对比:Fabric.js、Konva.js 和 Pixi.js
  • backbone是什么?
  • 四十篇:内存巨擘对决:Redis与Memcached的深度剖析与多维对比
  • HTML5的多线程技术:Web Worker API
  • Java | Leetcode Java题解之第206题反转链表
  • 660错题
  • GAMES104:04游戏引擎中的渲染系统1:游戏渲染基础-学习笔记
  • Visual Studio 中的键盘快捷方式
  • K8S中的某个容器突然出现内存和CPU占用过高的情况解决办法
  • Pointnet++改进即插即用系列:全网首发GLSA聚合和表示全局和局部空间特征|即插即用,提升特征提取模块性能
  • 如何选择适合自己的虚拟化技术?
  • Spring动态代理详解
  • Java微服务架构中的消息总线设计
  • 51单片机项目-点亮第一个LED灯(涉及:进制转换表、创建项目、生成HEX文件、下载程序到单片机、二极管区分正负极)
  • 安全管理中心测评项
  • word 转pdf 中图片不被压缩的方法
  • Springboot+Vue3开发学习笔记《1》
  • grpc编译
  • echarts-wordcloud:打造个性化词云库
  • VMware虚拟机安装CentOS7.9 Oracle 11.2.0.4 RAC+单节点RAC ADG
  • iOS 视图实现渐变色背景