PHP网站数据库查询慢时,可采用四种缓存方法:一、APCu扩展用于单机高频小数据;二、Redis支持分布式与多种数据结构;三、Memcached适用于高并发临时数据;四、文件缓存仅限低流量场景。

如果您的PHP网站面临数据库查询频繁、响应速度变慢的问题,则可能是由于未对高频读取的数据进行有效缓存。以下是几种在PHP中实现数据缓存的具体方法:
一、使用APCu扩展进行内存级缓存
APCu是PHP用户空间的共享内存缓存扩展,适用于单机部署环境,无需额外服务依赖,读写性能极高,适合缓存小体积、高频率访问的数据(如配置项、用户权限信息)。
1、确认PHP已启用apcu扩展:执行php -m | grep apcu,若无输出需安装并启用该扩展。
2、在PHP脚本中调用apcu_store()写入缓存:apcu_store('user_config', $config_array, 300),其中300表示缓存有效期为5分钟。
立即学习“PHP免费学习笔记(深入)”;
3、通过apcu_fetch()读取缓存:$data = apcu_fetch('user_config'),若返回false则需重新生成并再次存储。
4、使用apcu_exists()判断键是否存在,避免不必要的fetch空值判断。
二、采用Redis作为分布式缓存后端
Redis支持丰富的数据结构(字符串、哈希、列表等),具备持久化、主从同步与集群能力,适用于多服务器部署场景,可缓存会话、商品详情、排行榜等中等体积数据。
1、安装Redis服务并确保PHP已加载redis扩展(非phpredis旧名,需确认extension=redis.so已启用)。
2、实例化Redis客户端:$redis = new Redis(); $redis->connect('127.0.0.1', 6379);
3、设置带过期时间的缓存值:$redis->setex('product_1001', 3600, json_encode($product_data));
4、获取缓存并解码:$cached = $redis->get('product_1001'); $product_data = json_decode($cached, true);
三、利用Memcached进行轻量级键值缓存
Memcached专为高速缓存设计,内存管理高效,不支持持久化,适合临时性、非关键性数据(如页面片段、统计计数器),尤其在高并发短生命周期场景下表现稳定。
1、启动Memcached服务:memcached -d -m 128 -p 11211 -u nobody,分配128MB内存并监听默认端口。
51shop 由 PHP 语言开发, 使用快速的 MySQL 数据库保存数据 ,为中小型网站实现网上电子商务提供一个完美的解决方案.一、用户模块1. 用户注册:用户信息包括:用户ID、用户名、用户密码、性别、邮箱、省份、城市、 联系电话等信息,用户注册后不能立即使用,需由管理员激活账号,才可使用(此功能管理员可设置)2. 登录功能3. 资料修改:用户可修改除账号以后的所有资料4. 忘记密码:要求用
2、PHP中连接Memcached服务:$memcached = new Memcached(); $memcached->addServer('127.0.0.1', 11211);
3、写入缓存条目,设置超时时间为1800秒:$memcached->set('page_header_v2', $html_fragment, 1800);
4、尝试读取缓存,失败时返回null:$header = $memcached->get('page_header_v2');
四、基于文件系统的简易缓存实现
当无法安装扩展或仅需临时缓存且并发不高时,可使用PHP原生文件I/O构建轻量缓存层。该方式无需额外服务,但存在文件锁竞争与磁盘IO瓶颈,仅建议用于低流量后台管理界面或开发调试阶段。
1、定义缓存路径与键名哈希:$cache_file = '/tmp/cache/' . md5('user_list_page') . '.php';
2、检查缓存文件是否存在且未过期(例如10分钟):if (file_exists($cache_file) && (time() - filemtime($cache_file))
3、读取并反序列化缓存内容:$data = unserialize(file_get_contents($cache_file));
4、生成新缓存时,先序列化再写入文件:file_put_contents($cache_file, serialize($fresh_data));
五、结合OPcache优化PHP脚本字节码执行
OPcache将PHP脚本编译后的opcode缓存在共享内存中,避免重复解析与编译,显著提升脚本执行效率。它不缓存业务数据,但属于PHP运行层最关键的性能基础组件。
1、确认OPcache已启用:opcache.enable=1与opcache.enable_cli=1需同时设为1(后者便于CLI模式调试)。
2、调整最大缓存脚本数量:opcache.max_accelerated_files=20000,防止因文件过多导致缓存淘汰频繁。
3、禁用timestamp检查以提升生产环境稳定性:opcache.validate_timestamps=0(上线后需手动重启Web服务刷新opcode)。
4、设置共享内存大小为128MB:opcache.memory_consumption=128,确保足够容纳全部项目脚本opcode。










