加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 站长学院 > PHP教程 > 正文

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

发布时间:2020-12-13 02:17:25 所属栏目:PHP教程 来源:网络整理
导读:《PHP扩展模块memcached长连接使用方法分析》要点: 本文介绍了PHP扩展模块memcached长连接使用方法分析,希望对您有用。如果有疑问,可以联系我们。 PHP实例 ????? 网上广泛流传着一篇文章,讲述php的两个扩展模块memcache和memcached的区别,其中特意强调了m

《PHP扩展模块memcached长连接使用方法分析》要点:
本文介绍了PHP扩展模块memcached长连接使用方法分析,希望对您有用。如果有疑问,可以联系我们。

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

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

PHP实例? ?Creates a Memcached object,optionally using persistent memcache connection */

PHP实例static PHP_METHOD(Memcached,__construct)

PHP实例{

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

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

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

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

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

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

This is what you do not want to do:

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

PHP实例
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:

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

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

欢迎参与《PHP扩展模块memcached长连接使用方法分析》讨论,分享您的想法,编程之家 52php.cn为您提供专业教程。

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读