关闭

memcache的长连接表现。他是如何被重用的。

5300人阅读 评论(0) 收藏 举报
原贴:http://club.phpe.net/index.php?act=ST&f=15&t=14764&s=d60850b1e9f560fed16202431991de22

作者  memcache的长连接表现。他是如何被重用的。
flytod


新手上路


组别: 普通会员
发贴: 3
积分: 0



Posted:2006/12/07 12:50     Find all post by this member Copy post text,only for IE users 添加到PHPMORE知识书签
看了phpmore7,所有又回头看了一下手册里的memcache说明。发现一个以前没有注意到的pconnect()。
所以做了一下测试。

服务器:ubuntu 6.06,apt-get 安装的memcached
客户端:winxp,php 5.1.4 ,下载的php_memcache.dll

 
1 <?php 
2 $tmp_object = "cccccccccccc"
3  
4 $memcache_api = new Memcache; 
5 $memcache_api->pconnect('10.10.0.212', 11211); 
6 sleep(10); //这里sleep 10s,是为了在服务器端netstat 
7 print $memcache_api->add('key1'$tmp_object, false, 60); 
8 var_dump($memcache_api->get('key1')); 
9 ?> 
  view plain | print | ?


浏览器打开页面后,在服务器端通过# netstat -a |grep 11211查看
使用connect,打开一个窗口,结果是:
QUOTE
tcp        0      0 10.10.0.212:11211        10.10.0.4:2651          ESTABLISHED

浏览完成,再查看,链接已经没有了。
QUOTE
null


打开两个窗口,看见两个不同的链接,本地端口于上次2651不同,证明是新建立的
QUOTE
tcp        0      0 10.10.0.212:11211        10.10.0.4:2655          ESTABLISHED
tcp        0      0 10.10.0.212:11211        10.10.0.4:2653          ESTABLISHED



更换成pconnect后:
一个窗口浏览时:
QUOTE
tcp        0      0 10.10.0.212:11211        10.10.0.4:2659          ESTABLISHED


浏览结束后,再查看,链接依然存在

QUOTE
tcp        0      0 10.10.0.212:11211        10.10.0.4:2659          ESTABLISHED


新开两个窗口浏览,重用了前一个,再新建立了一个。

QUOTE
tcp        0      0 10.10.0.212:11211        10.10.0.4:2659          ESTABLISHED
tcp        0      0 10.10.0.212:11211        10.10.0.4:2662          ESTABLISHED


这个长链接是如何被重用的,是怎么在两次http请求之间保持的?是否和mysql的pconnect()是同样性质的吗?
static


正式会员


组别: 普通会员
发贴: 805
积分: 18



Posted:2006/12/07 20:06   Find all post by this member Copy post text,only for IE users 添加到PHPMORE知识书签
没读过代码, 估计一样, 因为没别的可能性
Ben


正式会员


组别: 普通会员
发贴: 93
积分: 2



Posted:2006/12/15 12:29       Find all post by this member Copy post text,only for IE users 添加到PHPMORE知识书签
没有看过 mysql pconnect的代码,不清楚 mysql pconnet 的实现,只是这两天在考虑给 memcache 添加一个同步啊、日志啊什么的功能,所以就瞅了下代码。

persistent 为 false 时的表现是很好理解的,请求来了就连接。请求完毕就关闭对 memcache server 的连接。至于 persistent 为 true 的情况,处理也是比较简单的。一个 memcache 的连接 hash 值主要跟 host、port 以及 timeout 有关。有一个连接请求到来时就根据host 和 port 生成一个 hash 值,然后查表。有则取出,没有则新建一个连接,新建后放入连接池。请求关闭时并不关闭对 memcache server 的连接,而是把这个连接(在做一些状态更新后)放入连接池(就是前面提到的那个 hash 表),供下次查询使用。

that's all~ smile_big.gif



是否我消失了,你才会知道我的存在……
 
0
0

查看评论
* 以上用户言论只代表其个人观点,不代表CSDN网站的观点或立场
    个人资料
    • 访问:3120470次
    • 积分:32829
    • 等级:
    • 排名:第145名
    • 原创:76篇
    • 转载:1209篇
    • 译文:0篇
    • 评论:200条
    最新评论
    牛逼的网站