PHP扩展模块memcached长连接使用方法分析


Posted in PHP onDecember 24, 2014

      网上广泛流传着一篇文章,讲述php的两个扩展模块memcache和memcached的区别,其中特意强调了memcached与memcached一个很大的区别是memcached模块不支持长连接。以至于后来很多年我都认为memcached是不支持长连接的,其实不然,memcached扩展模块从很早的版本开始就已经支持长连接了。从扩展模块的源码注视中我们就能看到:

/* {{{ Memcached::__construct([string persistent_id[, callback on_new[, string connection_str]]]))

   Creates a Memcached object, optionally using persistent memcache connection */

static PHP_METHOD(Memcached, __construct)

{

从php的手册身上我们可以看到memcached的扩展模块提供的构造函数提供一个参数persistent_id可选项,手册中这样介绍:

      默认情况下,Memcached实例在请求结束后会被销毁。但可以在创建时通过persistent_id为每个实例指定唯一的ID, 在请求间共享实例。所有通过相同的persistent_id值创建的实例共享同一个连接。 

这个参数的含义就是说如果你传递了一个命名id给到构造方法,那么就会建立长连接,通常我们使用的都是PHP-FPM模式,这样PHP-FPM进程就会和memcached服务简历一条长连接通道。我们也可以理解为persistent_id就是一个连接池名字,所有php-fpm进程都是这个连接池中的一员。

     但我们需要注意的是php是解释性语言,当php第一次通过memached模块建立起长连接后,切记后续的php执行就不要再通过memcached的构造函数构建相同persistent_id命名的长连接,可以建立不同persistent_id名字的长连接,如果是相同的名字被php重复执行,一定会导致php-fpm的进程异常导致与memcached的通信越来越慢,同时根据libmemcached的版本不同还会导致php产生coredump。

    那么我们如何避免单个php-fpm在建立完以persistent_id命名的长连接后不再重复建立长连接呢?其实在PHP带有评注的手册上是有讲解的,内容如下:

When using persistent connections, it is important to not re-add servers.

This is what you do not want to do:

$mc = new Memcached('mc');
$mc->setOption(Memcached::OPT_LIBKETAMA_COMPATIBLE, true);
$mc->addServers(array(
  array('mc1.example.com',11211),
  array('mc2.example.com',11211),
));

Every time the page is loaded those servers will be appended to the list resulting in many simultaneous open connections to the same server. The addServer/addServers functions to not check for existing references to the specified servers.

A better approach is something like:

$mc = new Memcached('mc');
$mc->setOption(Memcached::OPT_LIBKETAMA_COMPATIBLE, true);
if (!count($mc->getServerList())) {
  $mc->addServers(array(
    array('mc1.example.com',11211),
    array('mc2.example.com',11211),
  ));
}

通过使用getServerList()方法来检查当前执行使用的php-fpm进程容器中是否已经存在相同名字的长连接资源,如果存在就不要重复使用addServers() 方法来新增长连接配置。

PHP 相关文章推荐
discuz Passport 通行证 整合笔记
Jun 30 PHP
php抓取页面与代码解析 推荐
Jul 23 PHP
LotusPhp笔记之:Cookie组件的使用详解
May 06 PHP
php多功能图片处理类分享(php图片缩放类)
Mar 14 PHP
PHP文件锁定写入实例解析
Jul 14 PHP
php去掉文件前几行的方法
Jul 29 PHP
WordPress中用于检索模版的相关PHP函数使用解析
Dec 15 PHP
PHP+Ajax异步带进度条上传文件实例
Nov 01 PHP
PHP PDO操作MySQL基础教程
Jun 05 PHP
php curl获取到json对象并转成数组array的方法
May 31 PHP
YII框架http缓存操作示例
Apr 29 PHP
tp5.1 实现setInc字段自动加1
Oct 18 PHP
Yii框架在页面输出执行sql语句以方便调试的实现方法
Dec 24 #PHP
php使用pdo连接并查询sql数据库的方法
Dec 24 #PHP
php将access数据库转换到mysql数据库的方法
Dec 24 #PHP
php启用sphinx全文搜索的实现方法
Dec 24 #PHP
php中mail函数发送邮件失败的解决方法
Dec 24 #PHP
微信公众平台接口开发入门示例
Dec 24 #PHP
PHP获取youku视频真实flv文件地址的方法
Dec 23 #PHP
You might like
php中$_SERVER[PHP_SELF] 和 $_SERVER[SCRIPT_NAME]之间的区别
2009/09/05 PHP
PHP+Mysql+Ajax+JS实现省市区三级联动
2014/05/23 PHP
用PHP的socket实现客户端到服务端的通信实例详解
2017/02/04 PHP
php封装的mongodb操作类代码
2017/08/06 PHP
HTML5如何适配 iPhone IOS 底部黑条
2021/03/09 HTML / CSS
Nigma vs Alliance BO5 第一场2.14
2021/03/10 DOTA
JavaScript初学者应注意的七个细节详细介绍
2012/12/27 Javascript
JQuery实现点击div以外的位置隐藏该div窗口
2013/09/13 Javascript
JS实现日期时间动态显示的方法
2015/12/07 Javascript
js控制TR的显示隐藏
2016/03/04 Javascript
使用jquery.qrcode.min.js实现中文转化二维码
2016/03/11 Javascript
AngularJS 获取ng-repeat动态生成的ng-model值实例详解
2016/11/29 Javascript
原生js实现节日时间倒计时功能
2017/01/18 Javascript
JavaScript中最常见的三个面试题解析
2017/03/04 Javascript
Vue cli+mui 区域滚动的实例代码
2018/01/25 Javascript
vue项目base64字符串转图片的实现代码
2018/07/13 Javascript
使用koa2创建web项目的方法步骤
2019/03/12 Javascript
JS中的算法与数据结构之集合(Set)实例详解
2019/08/20 Javascript
javascript-hashchange事件和历史状态管理实例分析
2020/04/18 Javascript
vue中移动端调取本地的复制的文本方式
2020/07/18 Javascript
微信小程序实现电影App导航和轮播
2020/11/30 Javascript
Python os模块中的isfile()和isdir()函数均返回false问题解决方法
2015/02/04 Python
基于Django的ModelForm组件(详解)
2017/12/07 Python
详解python多线程、锁、event事件机制的简单使用
2018/04/27 Python
详解python3 + Scrapy爬虫学习之创建项目
2019/04/12 Python
Django stark组件使用及原理详解
2019/08/22 Python
python matplotlib模块基本图形绘制方法小结【直线,曲线,直方图,饼图等】
2020/04/26 Python
踩坑:pytorch中eval模式下结果远差于train模式介绍
2020/06/23 Python
波兰家居饰品和厨房配件网上商店:Maleomi
2020/12/15 全球购物
小学优秀班集体申报材料
2014/05/25 职场文书
房屋维修协议书范本
2014/09/25 职场文书
委托公证书样本
2015/01/23 职场文书
贫困证明怎么写
2015/06/16 职场文书
《圆的周长》教学反思
2016/02/17 职场文书
python学习之panda数据分析核心支持库
2021/05/07 Python
Golang Elasticsearches 批量修改查询及发送MQ
2022/04/19 Golang