首页 > 数据库 >Redis—问题(1)

Redis—问题(1)

时间:2022-10-22 22:23:38浏览次数:46  
标签:缓存 数据库 Redis 问题 内存 key 雪崩

写在前面

Redis 是一种 NoSQL 数据库,包含多种数据结构、支持网络、基于内存、可选持久性的键值对存储数据库,在我们的日常开发中会经常使用 Redis 来解决许多问题,比如排行榜、消息队列系统、计数器 以及 缓存系统等。

在作为缓存使用时,不可避免的会遇到缓存穿透、缓存雪崩、缓存击穿(热点 key) 的问题,那么究竟这些问题具体值的是什么,又该如何解决呢?

什么是缓存穿透

缓存穿透是指客户端请求的数据在缓存和数据库中都不存在,引起缓存失效,并会对数据库造成极大的压力。
常见的解决方案有两种:

  • 缓存空对象
    • 优点:实现简单,维护方便
    • 缺点:
      • 额外的内存消耗
      • 可能造成短期的不一致
  • 布隆过滤
    • 优点:内存占用少,没有多余的key
    • 缺点:
      • 实现复杂
      • 可能存在误判
  • 增加 id 的复杂度,避免被猜到 id 规律。
  • 做好数据的基础格式校验。
  • 加强用户的权限校验。
  • 做好热点参数的限流(sentinel)。

什么是缓存雪崩

缓存雪崩是指在同一时间段大量的缓存 key 同时失效或者 Redis 服务宕机,导致大量请求到达数据库,对数据库造成极大的压力。
常见的解决方案有:

  • 给不同的 key 的 TTL添加随机值。
  • 利用 Redis 集群提高服务的可用性。(Redis 主从,哨兵)
  • 给缓存业务添加降级限流策略(sentinel)。
  • 给业务添加多级缓存。

什么是缓存击穿

缓存击穿也叫热点 key 问题,是指一个被高并发访问并且缓存重建业务比较复杂的key 突然失效了,无数的请求访问会在瞬间给数据库带来巨大的冲击。
常见的解决方案有:

  • 互斥锁
    • 优点:
      • 没有额外的内存消耗
      • 保证一致性
      • 失效简单
    • 缺点:
      • 线程需要等待,性能收到影响
      • 可能有死锁的风险
  • 逻辑过期
    • 优点:
    • 线程无需等待,性能较好
    • 缺点:
      • 不保证一致性
      • 具有额外内存消耗
      • 实现复杂

总结

以上就是对缓存穿透、缓存雪崩、缓存击穿问题的简单介绍和解决办法,更加具体的实现方法,正在整理中...

标签:缓存,数据库,Redis,问题,内存,key,雪崩
From: https://www.cnblogs.com/xin666/p/16816351.html

相关文章

  • 2流高手速成记(之四):SpringBoot整合redis及mongodb
    最近很忙,好不容易才抽出了时间,咱们接上回上次我们主要讲了如何通过SpringBoot快速集成mybatis/mybatis-plus,以实现业务交互中的数据持久化,而这一切都是基于关系型数据库(SQ......
  • 8、CPU cache缓存一致性问题
    前面提到过现在CPU都是多核的,由于L1/L2Cache是多个核心各自独有的,L3Cache是多核共用的,那么会带来多核心的缓存一致性(CacheCoherence) 的问题,如果不能保证缓存一致性的......
  • 在线问题反馈模块实战(十三)​:实现多参数分页查询列表
    ......
  • 解码方法数问题
    解码方法数问题作者:Grey原文地址:博客园:解码方法数问题CSDN:解码方法数问题题目描述一条包含字母 A-Z的消息通过以下映射进行了编码:'A'->1'B'->2...'Z'->......
  • 爬虫中遇到登陆问题的解决方法
    在爬取网页时,由于会遇到登录问题而被阻止,此时通过改变头部信息来解决此问题以爬取京东商品页面为例1、先登录京东账号2、摁F12进入调试页面,然后刷新页面,在Network栏......
  • dremio 21 版本之后反射No File System scheme matches 问题解决
    实际属于一个老问题了,整理下,方便使用,主要是我们在使用反射的时候碰到的问题问题如下UnknownFormatConversionException:Conversion='Unknownformat(pdfs)conversio......
  • 区间问题----差分+离散化+前缀和
     《二维离散化+二维前缀和+二维双指针算法+二分+以点代二维区间》思路:首先,利用二分,将求解问题变成判断问题,二分边长关于在二维平面上的任意区域的数值问题可......
  • 单例 Bean 的线程安全问题
    最近面试遇到一个问题:单例Bean的线程安全问题怎么解决的。之前了解但是没有深究它的解决方法。大部分时候我们并没有在项目中使用多线程,所以很少有人会关注这个问题。......
  • dremio 23 s3 插件默认ssl 配置问题
    问题描述如下图  操作一般我们会按照(注意需要开启s3兼容模式),以上问题说明是依赖ssl,但是我们已经声明了不使用ssl  或者endpoint带上http如下,数据桶可......
  • Linux、数据库、Redis、MongoDB统一管理平台!
    #一、开源项目简介基于DDD分层实现的web版linux(终端文件脚本进程)、数据库(mysqlpostgres)、redis(单机集群)、mongo统一管理操作平台# 二、开源协议使用Apache-2.0......