百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术文章 > 正文

Redis缓存雪崩、缓存穿透、缓存预热、缓存更新

nanshan 2024-12-12 14:06 11 浏览 0 评论

缓存穿透

表示恶意用户模拟请求很多缓存中不存在的数据,由于缓存中都没有,导致这些请求短时间内直接落在数据库上,导致数据库异常。在实际项目就遇到过,比如有些抢购活动、秒杀活动的接口API被大量的恶意用户刷,导致短时间内数据库宕机。

解决方案:

  • 布隆过滤器BloomFilter

BloomFilter将所有可能存在的数据哈希后存放在一个足够大的Bitmap中,用于快速判断一个key是否不存在,不存在时直接返回,从而避免了对底层存储系统的查询压力,利用布隆过滤器,将redis缓存穿透控制在一个可容忍的范围内。

备注:

布隆过滤器的关键就在于hash算法和容器大小,

容器大小:比如数据库中有10000个key,那么布隆过滤器的容量capacity设置的要稍微比10000大一些,比如12000。

hash算法:同时由于hash算法会导致不同的key hash后的值是一样的,所以布隆过滤器存在一定的误判率,hash函数个数越多误判率越低,可以设置误判率。

private static BloomFilter<Integer> bloomFilter = BloomFilter.create(Funnels.integerFunnel(), capacity, 0.01);
  • 缓存层缓存空值

如果查询持久层返回的数据为空,缓存空值到缓存层,并设置过期时间,这样可以避免

  1. 缓存太多空值,占用更多空间
  2. 过期时间内的多次查询都会命中缓存,不会继续访问数据库
  3. 存储逻辑更新持久层数据后,待缓存层空值数据过期后,再次查询得到所需的结果数据

缓存雪崩

如果缓存集中在一段时间内出现大面积失效,所有访问请求都会查询数据库,导致数据库压力剧增等异常情况

解决方法:

  1. 不同的key,设置不同的过期时间,让缓存失效的时间点尽量均匀
  2. 缓存失效后,通过加锁或者队列来控制读数据库写缓存的线程数量(并发比较小时;分布式环境下需要分布式锁),该方案会引进其他问题,在真正的高并发场景下很少使用。
  3. 设置过期标志更新缓存:给每一个缓存数据增加相应的缓存标记,记录缓存的是否失效,如果缓存标记失效,则更新数据缓存,伪代码如下:
public String getProduct(String key){
        int cacheInterval = 30;
        String cacheKey = key;
        //缓存标记
        String cacheSign = cacheKey + "_sign";
        //获取缓存标记值
        String signValue = CacheUtil.get(cacheSign);
        //获取缓存值
        String cacheValue = CacheUtil.get(cacheKey);
        if (signValue != null){
            return cacheValue;//未过期,直接返回
        } else {
            CacheUtil.add(cacheSign, "1", cacheInterval);
            //从数据库中获取数据,一般是异步操作,以下2步可以放在子线程中操作
            cacheValue = getProductFromDB(cacheKey);
            //过期时间设置为2倍,用于在缓存过期时仍可以获取数据
            CacheUtil.add(cacheKey, "1", cacheInterval * 2);
            return cacheValue;
        }
    }

缓存预热

缓存预热就是系统上线后,提前将相关的缓存数据直接加载到缓存系统。避免在用户请求的时候,先查询数据库,然后再将数据缓存的问题!用户直接查询事先被预热的缓存数据!

解决方案:

  1. 上线前先通过代码把数据加载到缓存中;
  2. 数据量不大,可以在项目启动的时候自动进行加载;

缓存更新

除了缓存服务器自带的缓存失效策略之外(Redis默认的有6中策略可供选择),我们还可以根据具体的业务需求进行自定义的缓存淘汰,常见的策略有两种:

  1. 定时去清理过期的缓存;
  2. 当有用户请求过来时,再判断这个请求所用到的缓存是否过期,过期的话就去底层系统得到新数据并更新缓存。

两者各有优劣,第一种的缺点是维护大量缓存的key是比较麻烦的,第二种的缺点就是每次用户请求过来都要判断缓存失效,逻辑相对比较复杂!具体用哪种方案,大家可以根据自己的应用场景来权衡。

相关推荐

服务器温度监控--lm-sensors(服务器温度怎么看)

lm-sensors是一款linux的硬件监控的软件,可以帮助我们来监控主板,CPU的工作电压,风扇转速、温度等数据。这些数据我们通常在主板的BIOS也可以看到。当我们可以在机器运行的时候通过...

MySQL版本区别及管理(mysql版本最新版本)

MySQL版本区别及管理一.MySQL5.6与MySQL5.7安装的区别1、cmake的时候加入了bostorg2、初始化时使用mysqld--initialize替代mysql_install...

Linux技术问答系列-NO4(linux必知必会)

一.绝对路径用什么符号表示?当前目录、上层目录用什么表示?主目录用什么表示?切换目录用什么命令?绝对路径:如/etc/init.d当前目录和上层目录:./../主目录:~/切换目录:cd二...

猫盘原版系统开启ssh教程(猫盘原版系统怎么样)

猫盘是之前网上流传许久的矿渣,默认其系统不支持SSH功能,为了能打开其SSH功能,我特意制作操作教程如下:1、到网盘下载相关软件,利用猫盘系统自带功能,将assets放入个人存储目录下,并牢记对应的...

一探究竟——天融信网闸TopRules7000

网闸即:安全隔离与信息交换系统,常用作企业内外网隔离与业务互访用途。相比给服务器加多块网卡跨多个网段来说,网闸提供了更加安全的方式。探究背景:某次,网闸配置新业务,重启设备查看是否生效,结果发现刚重启...

操作系统加固通用Linux篇(linux系统加固常见操作)

1检查是否配置登陆超时时间设置编辑vi/etc/profile文件,配置TMOUT将值设置为低于300.TMOUT=3002检查是否禁止root用户登录FTP设置如下将对应配置文件中,设置roo...

zabbix agent的安装与配置(zabbix-agent安装)

Agent安装rpm-ivhzabbix-agent-3.2.4-1.el6.x86_64.rpm安装完成后,zabbixagent端已经安装完成了,zabbixagent端的配置目录位于/e...

Linux基础命令之计划任务(linux计划任务crontab)

一、计划任务1、at只能执行一次语法:at时间服务:atd必须开启123[root@xuegod163~]#/etc/init.d/atdstatus#查看服务状态atd(pid2...

Secure Delivery Center (SDC)安装指南二:Delivery Hub

免费下载SecureDeliveryCenter2015>7月23日软件分发管理神器SecureDeliveryCenter免费技术交流会,MyEclipse原厂商倾力主讲,敬请关注!...

OpenWrt 常用命令及用法!!(openwrt常用功能)

OpenWrt是一个高度可定制的嵌入式Linux操作系统,常用于路由器等网络设备。以下是一些常见的OpenWrt命令及其详细解释和示例操作:一、系统信息相关命令1.`uname-a``u...

Linux 设置定时任务crontab命令(linux定时任务cron表达式)

看了同事的脚本,发现他用了cron来自检自身的那个程序是否崩溃了,这是有多大的不自信才用这种机制的?点击(此处)折叠或打开$sudocat/var/spool/cron/crontabs/ro...

vCenter纳管ESXI主机出错(vsphere esxi)

vCenter纳管主机的大致步骤为:(1)vc和esxi交换证书,确立信任;(2)esxi把自己的资源信息同步到VC,VC建立清单。(3)VC在esxi建立几个操作用户;(4)然后下发...

从选购到安装 小白也能看懂的超全NAS经验分享

0.篇首语Hello大家好,我是KC,上一篇器材和工作流分享的文章里,有小伙伴问我怎么没有提到NAS?其实是因为前段时间碰巧更换了一台新NAS,折腾了一段时间很多内容还没来及整理和汇总,今天就...

手把手教你!如何在 Linux 服务器中搭建 Sentinel 环境?

你在Linux服务器上搭建Sentinel环境时,是不是也遇到过各种报错,要么是启动失败,要么是配置后无法正常访问控制台?看着同事顺利搭建好,自己却一头雾水,别提多着急了!其实,很多互联网大厂...

服务器被暴力破解的解决办法(二)(服务器被攻破严重吗)

上一次,我们说到小王公司服务器遭遇暴力破解,拿到解决方案回公司就开始部署。部署完成后的确起到了一定的效果,不过接下来的一个问题让他很头疼,原来黑客虽然攻入不进系统,但是依旧不依不饶的进行暴力破解。...

取消回复欢迎 发表评论: