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

网上广泛流传着一篇文章,讲述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的扩展模块提供的构造函数提供一个参数默认情况下,Memcached实例在请求结束后会被销毁。但可以在创建时通过为每个实例指定唯一的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:

setOption(Memcached::OPT_LIBKETAMA_COMPATIBLE,true);

$mc->addServers(array(

array('mc1.example.com',11211),array('mc2.example.com',));

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',));

}

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

总结

如果觉得编程之家网站内容还不错,欢迎将编程之家网站推荐给程序员好友。

本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值