0

0

缓存雪崩怎么办_PHP高并发缓存故障预防操作【方法】

看不見的法師

看不見的法師

发布时间:2026-02-14 17:18:02

|

942人浏览过

|

来源于php中文网

原创

缓存雪崩可通过随机化ttl和互斥锁预防:用random_int()为过期时间添加0–10分钟抖动,避免集中失效;用setnx+expire实现轻量锁,未获锁者休眠100ms后重试;慎用永不过期,须配合主动更新与内存策略。

缓存雪崩怎么办_php高并发缓存故障预防操作【方法】

缓存雪崩不是“会不会发生”的问题,而是“什么时候、以什么方式爆发”的问题——只要大量 Redis 缓存 key 设置了相同或高度集中的 expire 时间,高并发下就极大概率触发。


怎么设过期时间才不集体失效?用 random_int() 加偏移,别写死数字

PHP 里最常见也最危险的操作,就是所有用户、商品、订单缓存都统一写成 $redis->setex($key, 3600, $val)。3600 秒一到,全崩。

  • 基础 TTL(比如 3600 秒)只是参考值,真实过期时间必须带随机抖动
  • 推荐用 random_int(0, 600) 在基础值上加 0–10 分钟浮动,让失效时间分散在 3600–4200 秒区间
  • 不要用 rand(),它线程不安全;mt_rand() 也不如 random_int() 密码学安全且可预测性低
$baseTtl = 3600;
$jitter = random_int(0, 600);
$ttl = $baseTtl + $jitter;
$redis->setex($key, $ttl, $value);

注意:别把抖动设太大(比如 ±1 小时),否则冷热数据混在一起,缓存命中率反而下降。


缓存失效瞬间,怎么避免 100 个请求一起查数据库?用 setnx 做轻量级互斥锁

setnx 是 Redis 原生命令,PHP 客户端(如 Predis 或原生 Redis 扩展)都支持,比引入复杂锁服务更直接。

立即学习PHP免费学习笔记(深入)”;

Zeemo AI
Zeemo AI

一款专业的视频字幕制作和视频处理工具

下载
  • 锁 key 要和业务 key 强关联,例如 "lock:{$key}",防止误删
  • 必须配 expire,否则进程崩溃或异常退出会导致锁永远不释放(死锁)
  • 没抢到锁的请求,别立刻重试,用 usleep(100000)(100ms)再查一次缓存——多数情况下这时缓存已重建好
$lockKey = "lock:{$key}";
if ($redis->setnx($lockKey, 1)) {
    $redis->expire($lockKey, 10); // 锁最多持10秒
    $data = db_query($id);         // 查库
    $redis->setex($key, $ttl, json_encode($data));
    $redis->del($lockKey);
} else {
    usleep(100000);
    $data = $redis->get($key); // 再试一次
}

容易踩的坑:setnx 成功后忘记 expire,或者锁过期时间远短于数据库查询耗时(比如锁设 2 秒,DB 查询要 5 秒),导致多个请求同时进入重建逻辑。


要不要考虑“永不过期”?慎用,得配合主动更新机制

有人说“干脆不设 expire”,物理上避免雪崩。这在部分场景可行,但代价明确:

  • 数据一致性变难:缓存不会自动淘汰,必须靠业务逻辑触发更新(比如修改商品价格后,主动 $redis->set("product:123", $new)
  • 内存持续增长风险:没做 key 清理策略,旧数据越积越多,Redis 内存爆掉比雪崩还难排查
  • 不适合读多写少但时效敏感的场景(如活动倒计时、库存余量)

如果真要用永不过期,至少做到:

  • 所有写操作路径必须覆盖对应缓存 key 的更新或删除
  • 配合 RedisINFO memoryKEYS(生产禁用)或 SCAN 定期巡检大 key / 过期 key 残留
  • 开启 maxmemory-policy(如 allkeys-lru)作为兜底

监控和预热才是最后一道防线,光靠代码防不住人为失误

再完善的随机化 + 锁机制,也挡不住上线时批量 flushall、配置漏改、或新接口忘了加抖动。

  • 关键指标必须告警:redis_hit_rate(低于 85% 就预警)、redis_expired_keys(突增说明集中过期)、mysql_slow_queries
  • 预热脚本要在发布前跑:用 SCAN 扫出热点 key 模式(如 user:<em></em>product:hot),提前加载并设置带抖动的 TTL
  • 线上禁止直接执行 KEYS * 或未加 limit 的 SCAN,它们会阻塞 Redis 主线程

真正压垮系统的,往往不是技术方案本身,而是某次发布跳过了预热步骤,或是监控告警阈值设成了“等 DB 报错才通知”。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
硬盘接口类型介绍
硬盘接口类型介绍

硬盘接口类型有IDE、SATA、SCSI、Fibre Channel、USB、eSATA、mSATA、PCIe等等。详细介绍:1、IDE接口是一种并行接口,主要用于连接硬盘和光驱等设备,它主要有两种类型:ATA和ATAPI,IDE接口已经逐渐被SATA接口;2、SATA接口是一种串行接口,相较于IDE接口,它具有更高的传输速度、更低的功耗和更小的体积;3、SCSI接口等等。

1440

2023.10.19

PHP接口编写教程
PHP接口编写教程

本专题整合了PHP接口编写教程,阅读专题下面的文章了解更多详细内容。

362

2025.10.17

php8.4实现接口限流的教程
php8.4实现接口限流的教程

PHP8.4本身不内置限流功能,需借助Redis(令牌桶)或Swoole(漏桶)实现;文件锁因I/O瓶颈、无跨机共享、秒级精度等缺陷不适用高并发场景。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

2217

2025.12.29

java接口相关教程
java接口相关教程

本专题整合了java接口相关内容,阅读专题下面的文章了解更多详细内容。

37

2026.01.19

线程和进程的区别
线程和进程的区别

线程和进程的区别:线程是进程的一部分,用于实现并发和并行操作,而线程共享进程的资源,通信更方便快捷,切换开销较小。本专题为大家提供线程和进程区别相关的各种文章、以及下载和课程。

673

2023.08.10

线程和进程的区别
线程和进程的区别

线程和进程的区别:线程是进程的一部分,用于实现并发和并行操作,而线程共享进程的资源,通信更方便快捷,切换开销较小。本专题为大家提供线程和进程区别相关的各种文章、以及下载和课程。

673

2023.08.10

常用的数据库软件
常用的数据库软件

常用的数据库软件有MySQL、Oracle、SQL Server、PostgreSQL、MongoDB、Redis、Cassandra、Hadoop、Spark和Amazon DynamoDB。更多关于数据库软件的内容详情请看本专题下面的文章。php中文网欢迎大家前来学习。

993

2023.11.02

内存数据库有哪些
内存数据库有哪些

内存数据库有Redis、Memcached、Apache Ignite、VoltDB、TimesTen、H2 Database、Aerospike、Oracle TimesTen In-Memory Database、SAP HANA和ache Cassandra。更多关于内存数据库相关问题,详情请看本专题下面的文章。php中文网欢迎大家前来学习。

658

2023.11.14

pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法
pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法

本专题系统整理pixiv网页版官网入口及登录访问方式,涵盖官网登录页面直达路径、在线阅读入口及快速进入方法说明,帮助用户高效找到pixiv官方网站,实现便捷、安全的网页端浏览与账号登录体验。

76

2026.02.13

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
PHP课程
PHP课程

共137课时 | 11.8万人学习

JavaScript ES5基础线上课程教学
JavaScript ES5基础线上课程教学

共6课时 | 11.2万人学习

PHP新手语法线上课程教学
PHP新手语法线上课程教学

共13课时 | 0.9万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号