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 相关文章推荐
php header()函数使用说明
Jul 10 PHP
PHP合并两个数组的两种方式的异同
Sep 14 PHP
PHP对MongoDB[NoSQL]数据库的操作
Mar 01 PHP
解析php常用image图像函数集
Jun 24 PHP
PHP动态输出JavaScript代码实例
Feb 12 PHP
PHP时间和日期函数详解
May 08 PHP
PHP中PDO连接数据库中各种DNS设置方法小结
May 13 PHP
thinkphp制作404跳转页的简单实现方法
Sep 22 PHP
PHP get_html_translation_table()函数用法讲解
Feb 16 PHP
laravel执行php artisan migrate报错的解决方法
Oct 09 PHP
PHP cookie与session会话基本用法实例分析
Nov 18 PHP
tp5.0框架隐藏index.php入口文件及模块和控制器的方法分析
Feb 11 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判断手机浏览还是web浏览,并执行相应的动作简单实例
2016/07/28 PHP
javascript编程起步(第六课)
2007/01/10 Javascript
JavaScript EasyPager 分页函数
2011/05/25 Javascript
JavaScript利用正则表达式去除日期中的-
2014/06/09 Javascript
jquery实现实时改变网页字体大小、字体背景色和颜色的方法
2015/08/05 Javascript
XML文件转化成NSData对象的方法
2015/08/12 Javascript
jQuery中选择器的基础使用教程
2016/05/23 Javascript
使用jquery实现的循环连续可停顿滚动实例
2016/11/23 Javascript
Angularjs 依赖压缩及自定义过滤器写法
2017/02/04 Javascript
node.js的事件机制
2017/02/08 Javascript
nodejs+express实现文件上传下载管理网站
2017/03/15 NodeJs
Vue 2.0在IE11中打开项目页面空白的问题解决
2017/07/16 Javascript
Vue中如何实现proxy代理
2018/04/20 Javascript
js运算符的一些特殊用法
2018/07/29 Javascript
微信小程序 调用远程接口 给全局数组赋值代码实例
2019/08/13 Javascript
使用Vue调取接口,并渲染数据的示例代码
2019/10/28 Javascript
基于js实现判断浏览器类型代码实例
2020/07/17 Javascript
[02:28]DOTA2 2017国际邀请赛小组赛回顾
2017/08/09 DOTA
numpy中索引和切片详解
2017/12/15 Python
Python编程使用*解包和itertools.product()求笛卡尔积的方法
2017/12/18 Python
python+opencv实现动态物体识别
2018/01/09 Python
浅谈Python中的作用域规则和闭包
2018/03/20 Python
python验证码识别教程之灰度处理、二值化、降噪与tesserocr识别
2018/06/04 Python
Python字典推导式将cookie字符串转化为字典解析
2019/08/10 Python
pyinstaller打包找不到文件的问题解决
2020/04/15 Python
Windows 下更改 jupyterlab 默认启动位置的教程详解
2020/05/18 Python
使用keras内置的模型进行图片预测实例
2020/06/17 Python
北美大型运动类产品商城:Champs Sports
2017/01/12 全球购物
德国隐形眼镜店:LuckyLens
2018/07/29 全球购物
Hobbs官方网站:英国奢华女性时尚服装
2020/02/22 全球购物
厂长助理岗位职责
2013/12/27 职场文书
民主生活会对照检查材料思想汇报
2014/09/27 职场文书
道路交通事故人身损害赔偿协议书
2014/11/19 职场文书
2015中学教师个人工作总结
2015/07/22 职场文书
高中班长竞选稿
2015/11/20 职场文书
MySQL中优化SQL语句的方法(show status、explain分析服务器状态信息)
2022/04/09 MySQL