解决redis缓存击穿一次实践案例分析(redis缓存击穿案例)

解决Redis缓存击穿:一次实践案例分析

缓存击穿是经常会出现的一种缓存问题,它指的是在高并发的情况下,当查询的key不存在于缓存中且持久层也不存在对应的数据时,大量请求直接打到数据库上,导致数据库压力剧增,造成系统负载量瞬间增加,甚至可能导致系统宕机。本文将结合一次实践案例,分析如何解决Redis缓存击穿。

1. 缓存击穿案例

在我们的项目中主要存在两个高并发的场景,商品详情页和抢购活动页面。在这两个场景中,我们都采用了Redis作为缓存工具,当进行查询数据的时候,先从Redis缓存中查询,如果不存在则从数据库中查询,并将查询到的数据放入Redis缓存中。但是在一个繁忙的夜晚,发现系统的响应时间变得异常缓慢,甚至有的请求直接超时了。在进行线上调查后,我们发现了大量的缓存读取Miss的情况,即大量查询的key在Redis中不存在,Redis缓存被请求数量压垮,直接穿透下去打在了数据库上。

2. 常规解决方案

一般情况下,我们解决缓存击穿问题的方案如下:

2.1. 加锁

在缓存被Miss的时候,通过分布式锁来锁住当前的 key,然后让只能让一个线程去查询DB并写入缓存。这样其他的线程在查询缓存时,发现该 key 已被锁住,则等待该线程写入Redis之后再从缓存中获取数据即可。这种方式能够有效解决缓存击穿问题,但是在高并发场景下,会导致线程阻塞,可能会引起其他线程的超时。

2.2. 空值标识

当查询数据库结果为空时,我们可以将空结果也写入缓存中,但需要给空结果添加一个过期时间,防止脏数据继续滞留在缓存中。不过这种方式并不能完全解决缓存击穿问题,因为在cache和DB同时过期的情况下,还是会出现缓存穿透问题。

2.3. 数据预加载

预先将热点数据加载至缓存,然后通过一定的策略进行缓存更新,这样能够有效避免缓存失效带来的穿透问题。但需要注意的是,预加载的数据量不能太大,否则会导致Redis短时间内压力过大,影响其他服务的正常使用。

3. 实践案例

针对上述常规解决方案的缺陷,我们结合具体场景,提出了一种比较高效的解决方案。具体做法如下:

3.1. 在查询redis缓存数据时,先查询缓存中是否存在该数据,如果不存在,则将对应的缓存 key 加锁,防止其他线程穿透下去查询数据库。采用如下Lua脚本:

-- Redis查询脚本,先查询缓存数据,如果不存在则加锁查询DB
-- key:缓存Key
-- db_function:查询数据库的函数名
-- value:缓存过期时间
local res = redis.call('get', KEYS[1])
if(res == false or res == ngx.null) then
res = redis.call('set', KEYS[1], KEYS[2], 'NX', 'EX', KEYS[3])
if(res == false or res == ngx.null) then
-- 已经有其他线程获取锁并从DB写入的数据,继续从cache中查询
return nil
else
-- 获取锁成功,从DB中查询数据
local resp = _G[KEYS[4]]()
if(resp == false or resp == ngx.null) then
redis.call('set', KEYS[1], 'NULL', 'EX', KEYS[3])
return nil
else
-- 写入缓存
redis.call('set', KEYS[1], resp, 'EX', KEYS[3])
return resp
end
end
else
return res
end

3.2. 在查询数据库时,加入短暂的等待,让另一个线程在写入cache之后,当前线程再从cache中查询数据即可。

// 简化后的查询数据库部分代码
Object data = null;
try {
data = cache.get(key);
if (data == null) {
// 设置短暂等待时间,让其他线程更多的机会去缓存中查询
Thread.sleep(50L);
// 再次查询缓存
data = cache.get(key);
if (data == null) {
data = queryFromDB(key);
cache.set(key, data, expireTime);
}
}
} catch (Exception e) {
logger.error("Get data from redis error: ", e);
}

4. 总结

缓存击穿是Redis中经常出现的缓存问题,针对不同的场景,我们可采取不同的解决方案。本文主要针对高并发场景下,结合实践案例提供了一种比较高效的解决方案,以供读者参考。值得注意的是,在解决缓存问题的过程中,我们要注意balabala……(这里可以添加其他笔者认为需要注意的点)

香港服务器首选树叶云,2H2G首月10元开通。
树叶云(www.IDC.Net)提供简单好用,价格厚道的香港/美国云服务器和独立服务器。IDC+ISP+ICP资质。ARIN和APNIC会员。成熟技术团队15年行业经验。

文章来源网络,作者:运维,如若转载,请注明出处:https://shuyeidc.com/wp/301901.html<

(0)
运维的头像运维
上一篇2025-05-24 13:24
下一篇 2025-05-24 13:26

相关推荐

  • 个人主题怎么制作?

    制作个人主题是一个将个人风格、兴趣或专业领域转化为视觉化或结构化内容的过程,无论是用于个人博客、作品集、社交媒体账号还是品牌形象,核心都是围绕“个人特色”展开,以下从定位、内容规划、视觉设计、技术实现四个维度,详细拆解制作个人主题的完整流程,明确主题定位:找到个人特色的核心主题定位是所有工作的起点,需要先回答……

    2025-11-20
    0
  • 社群营销管理关键是什么?

    社群营销的核心在于通过建立有温度、有价值、有归属感的社群,实现用户留存、转化和品牌传播,其管理需贯穿“目标定位-内容运营-用户互动-数据驱动-风险控制”全流程,以下从五个维度展开详细说明:明确社群定位与目标社群管理的首要任务是精准定位,需明确社群的核心价值(如行业交流、产品使用指导、兴趣分享等)、目标用户画像……

    2025-11-20
    0
  • 香港公司网站备案需要什么材料?

    香港公司进行网站备案是一个涉及多部门协调、流程相对严谨的过程,尤其需兼顾中国内地与香港两地的监管要求,由于香港公司注册地与中国内地不同,其网站若主要服务内地用户或使用内地服务器,需根据服务器位置、网站内容性质等,选择对应的备案路径(如工信部ICP备案或公安备案),以下从备案主体资格、流程步骤、材料准备、注意事项……

    2025-11-20
    0
  • 如何企业上云推广

    企业上云已成为数字化转型的核心战略,但推广过程中需结合行业特性、企业痛点与市场需求,构建系统性、多维度的推广体系,以下从市场定位、策略设计、执行落地及效果优化四个维度,详细拆解企业上云推广的实践路径,精准定位:明确目标企业与核心价值企业上云并非“一刀切”的方案,需先锁定目标客户群体,提炼差异化价值主张,客户分层……

    2025-11-20
    0
  • PS设计搜索框的实用技巧有哪些?

    在PS中设计一个美观且功能性的搜索框需要结合创意构思、视觉设计和用户体验考量,以下从设计思路、制作步骤、细节优化及交互预览等方面详细说明,帮助打造符合需求的搜索框,设计前的规划明确使用场景:根据网站或APP的整体风格确定搜索框的调性,例如极简风适合细线条和纯色,科技感适合渐变和发光效果,电商类则可能需要突出搜索……

    2025-11-20
    0

发表回复

您的邮箱地址不会被公开。必填项已用 * 标注