PHP缓存核心目标是减少重复计算和数据库查询以提升响应速度,主要分文件缓存(适合低频更新、零成本部署)、APCu(进程内内存缓存、轻量高效但不跨进程)和Redis(分布式共享、适合多实例协作),需依数据规模、更新频率与部署结构合理选型。

PHP缓存的核心目标是减少重复计算和数据库查询,提升响应速度。合理使用文件缓存和内存缓存(如Redis、APCu),能显著降低服务器压力,尤其在高并发或内容变动不频繁的场景下效果明显。
文件缓存:简单直接,适合低频更新场景
文件缓存把处理结果序列化后写入磁盘,下次请求直接读取,跳过耗时逻辑。它无需额外服务,部署零成本,特别适合静态页面、配置数据或报表类内容。
- 用 file_put_contents() 和 file_get_contents() 配合 serialize()/unserialize() 或 json_encode()/json_decode() 存取数据
- 务必加缓存有效期判断:读取前检查文件修改时间(filemtime()),超时则重建缓存
- 缓存文件路径建议按业务分类,避免集中存放;文件名可用 key 的 md5 值,防止特殊字符和冲突
- 注意权限问题:确保 PHP 进程对缓存目录有读写权限;生产环境禁用 eval() 或动态包含缓存文件,防止代码注入
APCu 缓存:进程内内存缓存,轻量高效
APCu 是 PHP 内置的用户数据缓存扩展,数据存在 PHP 进程内存中,读写极快,适合存储小而热的数据,比如用户会话片段、接口返回的通用配置。
- 启用前确认已安装并开启扩展(extension=apcu.so,CLI 模式默认关闭,需设 apc.enable_cli=1)
- 常用函数:apcu_store($key, $value, $ttl) 写入,apcu_fetch($key) 读取,apcu_exists($key) 判断是否存在
- 注意:APCu 数据仅限当前进程有效,不跨 PHP-FPM worker 共享;重启 PHP 服务后全部丢失,不适合持久化关键数据
- 可通过 apcu_clear_cache('user') 清理用户缓存,调试时可用 apcu_info() 查看命中率与内存使用
Redis 缓存:分布式共享,适合多实例协作
当项目部署多个 PHP 实例(如负载均衡集群),必须用 Redis 这类外部缓存服务,保证所有节点访问同一份缓存数据。
立即学习“PHP免费学习笔记(深入)”;
- 推荐使用 predis/predis 或 phpredis 扩展;后者性能更高,但需编译安装
- 键名设计建议带业务前缀(如 user:profile:123),便于批量管理;用 SET key value EX 3600 设置带过期的字符串值
- 复杂结构优先用 Hash(HSET/HGETALL)或 JSON 字符串存储,避免大 Value 占用过多内存
- 务必设置连接超时与重试机制;缓存失效时做好降级处理(如直接查库),防止“缓存雪崩”
基本上就这些。文件缓存够用就别上 Redis,APCu 快但别当数据库用,Redis 强大但得管好连接和过期策略。选哪种,看数据规模、更新频率和部署结构。











