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

原贴: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); 
6sleep(10); //这里sleep 10s,是为了在服务器端netstat 
7print $memcache_api->add('key1'$tmp_object, false, 60); 
8var_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



是否我消失了,你才会知道我的存在……
 
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值