当前位置:首页 > 文章列表 > 文章 > php教程 > PHP如何连接并操作Memcached协议的数据库_使用memcached扩展

PHP如何连接并操作Memcached协议的数据库_使用memcached扩展

2026-05-02 20:32:56 0浏览 收藏

本篇文章给大家分享《PHP如何连接并操作Memcached协议的数据库_使用memcached扩展》,覆盖了文章的常见基础知识,其实一个语言的全部知识点一篇文章是不可能说完的,但希望通过这些问题,让读者对自己的掌握程度有一定的认识(B 数),从而弥补自己的不足,更好的掌握它。

必须先确认PHP的memcached扩展已安装并启用,否则new Memcached()会报Class 'Memcached' not found;实例化后需显式调用addServer()添加服务器,构造函数不支持传参连接,且set()/get()失败默认静默返回false,须用getResultCode()校验。

PHP如何连接并操作Memcached协议的数据库_使用memcached扩展

PHP连接Memcached服务前必须确认扩展已加载

直接调用 new Memcached() 报错 Class 'Memcached' not found,基本等于扩展没装或没启用。不是写法问题,是环境缺失。

检查方式很简单:
php -m | grep memcached(命令行)
或在 Web 环境中输出 phpinfo(),搜索 “memcached” 模块是否列出、版本是否 ≥ 2.0.0(旧版如 1.x 不支持 SASL、部分选项会失效)。

  • Ubuntu/Debian:装 php-memcached 包(注意不是 php-memcache,后者是另一个更老的扩展)
  • macOS(Homebrew + PHP 8.x):用 pecl install memcached,确保 libmemcached 已安装且版本 ≥ 1.0.18
  • Windows:下载对应 PHP 版本和线程安全(TS/NTS)的 php_memcached.dll,加到 extension_dir 并在 php.ini 中添加 extension=php_memcached.dll

new Memcached() 后必须手动 addServer,不能靠构造函数自动连

Memcached 类的构造函数不接受地址参数,传了也忽略。常见错误是写成 new Memcached('127.0.0.1', 11211),这不会报错但实际没连上任何服务器——后续所有 set()get() 都静默失败或返回 false。

正确流程是两步:实例化 → 显式添加节点:

$mc = new Memcached();
$mc->addServer('127.0.0.1', 11211); // 可多次调用加多个节点
// 注意:addServer 不校验连通性,失败只在第一次操作时暴露
  • 如果服务不可达,get() 返回 falseset() 返回 false,但不会抛异常
  • $mc->getServerList() 确认节点已注册;用 $mc->getStats() 查看各节点状态(返回数组,键为 host:port,值为统计信息或 false
  • 生产环境建议加简单连通性兜底,比如 if (!$mc->getVersion()) { throw new RuntimeException('Memcached server unreachable'); }

set() 和 get() 的第三个参数决定数据是否过期,别依赖默认行为

set($key, $value, $expiration)$expiration 参数不是“秒数”那么简单:小于等于 30 天(2592000 秒)按秒算;大于则按 Unix 时间戳解释。这个隐式切换极易导致缓存长期不更新或秒级就失效。

例如:$mc->set('foo', 'bar', 3600) 是 1 小时后过期;但 $mc->set('foo', 'bar', 1717027200)(2024-05-30 时间戳)会被当成绝对时间,若当前时间已超,缓存立刻失效。

  • 推荐统一用相对时间,且显式写清楚单位:$mc->set('key', $val, 600) 表示 10 分钟
  • get() 没有超时参数,只负责读;不存在的 key 直接返回 false,无法区分“key 不存在”和“key 存在但值就是 false”——需要业务层约定空值兜底(如存 null 时改存 '__NULL__' 字符串)
  • 批量操作用 setMulti()/getMulti(),它们的过期时间参数是统一的整数值,不支持 per-key 过期

多服务器部署时,一致性哈希和故障转移需手动配置

默认情况下 Memcached 扩展使用标准哈希(CRC32),节点增减会导致大量 key 重分布、缓存雪崩。它不自动启用一致性哈希,也不自动踢掉宕机节点。

开启一致性哈希只需一行:$mc->setOption(Memcached::OPT_LIBKETAMA_COMPATIBLE, true)。之后新增或下线一个节点,只有约 1/N 的 key 会迁移(N 为节点数)。

  • 故障节点不会自动剔除:即使 addServer() 加了 3 个节点,其中一个挂了,set() 仍可能路由过去并失败。要用 $mc->setOption(Memcached::OPT_AUTO_EJECT_HOSTS, true) 启用自动摘除,并配合 Memcached::OPT_SERVER_FAILURE_LIMITMemcached::OPT_RETRY_TIMEOUT 控制摘除策略
  • 所有 setOption 必须在 addServer() 之后、首次操作之前调用,否则无效
  • 一致性哈希开启后,getServerByKey($key) 可查某个 key 当前路由到哪个节点,方便排查分片问题
Memcached 协议本身无认证,扩展也不支持密码(不像 Redis)。如果服务暴露在非可信网络,必须靠防火墙或代理层控制访问,别指望客户端做权限隔离。

本篇关于《PHP如何连接并操作Memcached协议的数据库_使用memcached扩展》的介绍就到此结束啦,但是学无止境,想要了解学习更多关于文章的相关知识,请关注golang学习网公众号!

Yii框架如何上传大文件_Yii框架分片上传处理方案【功能】Yii框架如何上传大文件_Yii框架分片上传处理方案【功能】
上一篇
Yii框架如何上传大文件_Yii框架分片上传处理方案【功能】
PHP怎样获取栏目多语言版本_PHP多语言栏目取法【国际】
下一篇
PHP怎样获取栏目多语言版本_PHP多语言栏目取法【国际】
查看更多
最新文章
查看更多
课程推荐
  • 前端进阶之JavaScript设计模式
    前端进阶之JavaScript设计模式
    设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
    543次学习
  • GO语言核心编程课程
    GO语言核心编程课程
    本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
    516次学习
  • 简单聊聊mysql8与网络通信
    简单聊聊mysql8与网络通信
    如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
    500次学习
  • JavaScript正则表达式基础与实战
    JavaScript正则表达式基础与实战
    在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
    487次学习
  • 从零制作响应式网站—Grid布局
    从零制作响应式网站—Grid布局
    本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
    485次学习
查看更多
AI推荐
  • 剧云 - 免费 AI 智能中文剧本创作平台
    剧云
    剧云是专业中文剧本创作平台,安全稳定运行十余年,集成AI编剧、剧本医生审核、人物小传、剧情关系图、大纲编写、多人协作、Word导入导出、版权管控功能,数据安全防护,轻松高效创作剧本。
    96次使用
  • 万象有声 - AI 一站式有声内容创作平台
    万象有声
    万象有声,一个专为有声创作者打造的新一代智能有声内容创作平台。平台提供专业的智能拆章、智能画本编辑、AI配音、AI生成音效、后期制作、智能对轨、智能审听等有声创作全流程工具,可以帮助创作者高效、低成本创作出引人入胜的有声作品。立即体验,让有声书制作更简单!
    100次使用
  • Red Skill - 小红书推出的 AI Skill 分发平台
    Red Skill
    小红书创作服务平台为小红书创作者和机构提供视频上传、数据分析、粉丝管理、创作指导等多项运营服务,助力用户解锁更多创作者专属功能,体验高效创作!
    101次使用
  • MiMo Code - 小米大模型团队开源的新一代 AI 编程助手
    MiMo Code
    MiMo Code 是小米大模型团队开源的新一代 AI 编程助手,面向开发者提供代码理解、生成与辅助开发能力,适合作为 AI 编程工具收藏和体验。
    203次使用
  • TRAE Work - 字节跳动推出的 AI 原生工作台
    TRAE Work
    TRAE AI IDE | 国内首款 AI 原生集成开发环境,深度集成 Doubao-1.5-pro 与 DeepSeek 模型,支持中文自然语言一键生成完整代码框架,实时预览前端效果并智能修复 BUG。首创 Builder 模式实现需求到代码的自动化开发,兼容 Windows/macOS 系统,官网下载即用。
    234次使用
微信登录更方便
  • 密码登录
  • 注册账号
登录即同意 用户协议隐私政策
返回登录
  • 重置密码