ThinkPHP通过配置文件config/cache.php设置缓存,支持file、redis、memcached等驱动,推荐生产环境使用Redis;通过Cache类进行set、get、delete操作,可指定驱动和过期时间;优化策略包括合理设置过期时间、使用前缀区分模块、避免缓存穿透、批量操作及监控命中率,有效提升性能并降低数据库压力。

ThinkPHP 的缓存机制为提升应用性能提供了重要支持,合理配置和优化缓存能显著减少数据库压力、加快页面响应速度。本文将介绍 ThinkPHP 中缓存的配置方式、常用驱动设置以及优化策略,帮助开发者更高效地使用缓存功能。
缓存配置方式
在 ThinkPHP 5 或 ThinkPHP 6 中,缓存配置主要通过配置文件完成。以 ThinkPHP 6 为例,缓存配置位于 config/cache.php 文件中,核心配置项包括默认缓存驱动、缓存前缀、过期时间等。
基本配置示例如下:
return [
// 默认缓存驱动
'default' => 'redis',
// 缓存前缀,避免键名冲突
'prefix' => 'tp6_',
// 默认缓存时间(秒),0 表示永久缓存
'expire' => 3600,
// 各种缓存驱动配置
'stores' => [
'file' => [
'type' => 'File',
'path' => runtime_path() . 'cache',
'serialize' => true,
],
'redis' => [
'type' => 'Redis',
'host' => '127.0.0.1',
'port' => 6379,
'password' => '',
'select' => 0,
'timeout' => 3,
],
'memcached' => [
'type' => 'Memcached',
'host' => '127.0.0.1',
'port' => 11211,
'weight' => 1,
]
],
];
通过修改 default 值可切换默认缓存驱动,支持 file、redis、memcached、apc 等多种类型。
立即学习“PHP免费学习笔记(深入)”;
常用缓存驱动说明
不同缓存驱动适用于不同场景,选择合适的驱动对性能影响较大。
- File(文件缓存):最简单易用,适合小型项目或开发环境。数据存储在文件系统中,读写效率较低,不适合高并发场景。
- Redis:高性能内存数据库,支持持久化、分布式部署,适合大中型项目。常用于会话缓存、热点数据存储。
- Memcached:纯内存缓存系统,速度快,但不支持数据持久化,适合临时数据缓存。
- Apcu:PHP 内部缓存,仅限单机使用,适合 PHP-FPM 环境下的简单加速。
生产环境推荐使用 Redis,兼具性能与可靠性。
缓存使用方法
ThinkPHP 提供了统一的 Cache 类进行操作,使用非常简便。
use think\facade\Cache;
// 设置缓存
Cache::set('user_1001', ['name' => '张三', 'age' => 28], 3600);
// 获取缓存
$data = Cache::get('user_1001');
// 删除缓存
Cache::delete('user_1001');
// 清空缓存(当前驱动下所有)
Cache::clear();
也可指定特定缓存驱动:
Cache::store('file')->set('temp_data', 'abc');
Cache::store('redis')->get('user_1001');
缓存优化策略
合理使用缓存不仅能提升性能,还能降低服务器负载。以下是几条实用优化建议:
- 设置合理的过期时间:高频变动数据设置较短有效期,静态内容可适当延长,避免缓存 stale 数据。
- 使用缓存前缀区分模块:如 user:, order:, config:,便于管理和清理。
- 避免缓存穿透:对查询结果为空的数据也做缓存(如 null 值),并设置较短过期时间。
- 批量操作优化:Redis 支持 mget/mset,尽量减少网络请求次数。
- 监控缓存命中率:定期检查缓存使用情况,命中率低时需重新评估键设计或失效策略。
对于复杂查询或接口数据,可结合事件监听或中间件自动缓存响应结果,进一步提升效率。
基本上就这些,只要配置得当,ThinkPHP 的缓存机制能有效支撑大多数 Web 应用的性能需求。关键是根据业务特点选择合适驱动,并持续优化缓存策略。不复杂但容易忽略细节,比如前缀冲突或未及时清除旧缓存。










