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

Redis 缓存预热、雪崩、穿透、击穿

  1. 缓存预热
    1. 缓存预热是什么
      1. 缓存预热就是系统上线后,提前将相关的缓存数据直接加载到缓存系统。避免在用户请求的时候,先查询数据库,然后再将数据缓存的问题!用户直接查询事先被预热的缓存数据!
    2. 解决方案
      1. 使用 @PostConstruct 、定时任务、手动处理 提前将数据设置到缓存中

  2. 缓存雪崩
    1. 缓存雪崩是什么
      1. 缓存雪崩就是瞬间过期数据量太大,导致对数据库服务器造成压力

    2. 发生场景

      1. redis 主机挂了, Redis全盘崩溃,偏硬件运维
      2. redis 中有大量key 同时过期大面积失效,偏软件开发
    3. 解决+预防方案
      1. redis 中 key 设置为永不过期 or 过期时间错开
      2. redis 缓存集群实现高可用
        • 主从 + 哨兵
        • Redis 集群
        • 开启Redis 持久化机制 aof / rdb,尽快恢复缓存集群
      3. 多缓存结合预防雪崩
        • ehcache 本地缓存 + redis缓存
      4. 服务降级
        • Hystrix 或者 sentinel 限流 & 降级
  3. 缓存穿透
    1. 缓存穿透是什么
      1. 缓存穿透 就是请求去查询一条数据,先查redis,redis里面没有,再查mysql,mysql里面无,都查询不到该条记录,但是请求每次都会打到数据库上面去,导致后台数据库压力暴增
    2. 解决方案
      1. 空对象缓存或者缺省值, 如果发生缓存穿透,可以针对要查询的数据,在Redis里存一个和业务部门商量后确定的缺省值 比如 零、负数、defaultNull等
      2. 使用布隆过滤器,将key放到布隆过滤器中,请求来了用布隆过滤器判断key是否存在,如果存在则走后续逻辑,不存在则直接返回
  4. 缓存击穿
    1. 缓存击穿是什么
      1. 缓存击穿就是大量请求同时查询一个key时,此时这个key正好失效了,就会导致大量的请求都打到数据库上面去,也就是热点key突然都失效了,MySQL承受高并发量
    2. 解决方案
      1. 差异失效时间,对于访问频繁的热点key,干脆就不设置过期时间
      2. 互斥更新,采用双检加锁
  5. 总结
    1.  
http://www.lryc.cn/news/422891.html

相关文章:

  • 仿RabbiteMq简易消息队列基础篇(gtest的使用)
  • 图像处理中的图像梯度和幅值是什么???(通俗讲解)
  • 01.计算机网络导论
  • API网关:SpringCloud GateWay
  • 【Leetcode 383】赎金信 —— 哈希表 有注解
  • Linux 常见的冷知识集锦
  • 【喜报】科大睿智祝贺青岛海信网络科技通过CMMI5级评估
  • 2024全国大学生电子设计大赛全国初赛 E题 三子棋游戏装置 一等奖满分最简方案
  • 尚品汇-ES(三十一)
  • NC 跳台阶
  • linux 文件编程
  • 【后端速成 Vue】实现动态表白墙
  • 【日常开发】 java返回ECharts数据结构封装
  • Table表格控件实现单选功能
  • AI技术加速落地 港科广联手思谋打开智能缺陷检测新纪元
  • Python爬虫开发:BeautifulSoup、Scrapy入门
  • 数据科学、数据分析、人工智能必备知识汇总-----常用数据分析方法-----持续更新
  • 学习vue Router 一 起步,编程式导航,历史记录,路由传参
  • Qt/C++最新地图组件发布/历时半年重构/同时支持各种地图内核/包括百度高德腾讯天地图
  • Laravel + Thinkphp 生成二维码
  • 2408C++,C++20的无侵入式反射
  • 抽象工厂模式(Abstract factory pattern)- python实现
  • adb Connection reset by peer的解决方法
  • 111111111
  • 搜维尔科技:Varjo XR-4使用UE5 打造最具沉浸感的混合现实环境
  • 从分散到集中:TSINGSEE青犀EasyCVR视频汇聚网关在视频整体监控解决方案中的整合作用
  • React学习-jsx语法
  • uniapp多图上传uni.chooseImage上传照片uni.uploadFile
  • 鸿蒙(API 12 Beta2版)媒体开发【处理音频焦点事件】
  • c语言第12天