在php中使用memcached是为了提升网站性能并减少数据库压力。首先,安装memcached扩展需依赖libmemcached库,在linux系统下用apt-get安装,macos用brew安装,并在php.ini中添加extension=memcached.so后重启服务;其次,基本使用包括连接服务器、设置缓存(set)、获取缓存(get)和删除缓存(delete),支持多key操作提高效率;最后,分布式环境下可配置多个节点,采用一致性哈希算法分配key,并通过调整权重控制流量分布,同时结合主动更新或懒更新策略处理缓存失效问题。
在PHP中使用Memcached,主要是为了提升网站性能,减少数据库压力。尤其是面对高并发场景时,通过Memcached缓存热点数据能显著提高响应速度。关键在于如何配置和使用它,尤其是在分布式环境下。
安装Memcached扩展
要使用Memcached,首先要确保你的PHP环境中已经安装了memcached扩展。这个扩展依赖于libmemcached库,所以安装过程比简单的PECL模块略复杂一点。
- linux系统下可以通过包管理器安装:
sudo apt-get install php-memcached
- Macos可以用brew:
brew install libmemcached pecl install memcached
安装完成后记得在php.ini中添加:
立即学习“PHP免费学习笔记(深入)”;
extension=memcached.so
重启服务后用phpinfo()检查是否生效。
基本使用方法
连接Memcached服务器是第一步。你可以连接单个或多个节点。基本操作包括设置、获取、删除缓存项。
示例代码如下:
$memcached = new Memcached(); $memcached->addServer('127.0.0.1', 11211); // 设置缓存 $memcached->set('user_123', ['name' => '张三', 'age' => 25], 3600); // 获取缓存 $user = $memcached->get('user_123'); // 删除缓存 $memcached->delete('user_123');
注意几个点:
- set的第三个参数是过期时间,单位是秒。
- 如果key不存在,get返回false。
- 可以一次操作多个key(比如getMulti),效率更高。
分布式缓存配置技巧
当你的应用部署在多台服务器上时,Memcached可以作为共享缓存层来使用。这时候需要配置多个Memcached节点,并合理设置负载策略。
例如:
$servers = [ ['192.168.1.10', 11211, 33], ['192.168.1.11', 11211, 33], ['192.168.1.12', 11211, 34] ]; $memcached = new Memcached(); $memcached->addServers($servers);
这里有几个建议:
- 使用一致性哈希算法分配key到不同节点:$memcached->setOption(Memcached::OPT_LIBKETAMA_COMPATIBLE, true);
- 每个节点的权重可以不一样,用来控制流量分布。
- 节点之间不通信,适合读多写少的场景。
如果其中一台服务器宕机,Memcached会自动跳过它,但缓存穿透问题需要你自己处理。
缓存失效与更新策略
缓存不是永久的,设置合适的过期时间很重要。一般有几种方式:
- 固定过期时间,比如文章详情缓存一小时。
- 主动更新,在数据变更时清除旧缓存。
- 使用“懒更新”策略,缓存失效后重新生成。
举个例子:用户修改了资料,你应该主动删除对应缓存:
$memcached->delete('user_'.$userId);
这样下次访问就会重新加载最新数据,避免脏读。
另外,对于一些频繁查询又不常变的数据,比如城市列表、分类信息等,非常适合放在缓存里,能省不少数据库资源。
基本上就这些。Memcached用起来不难,但要真正发挥它的作用,得结合业务场景做合理设计。比如什么时候缓存、怎么分片、如何应对缓存击穿等问题,都需要根据实际情况调整策略。