解决memcache连接奇慢问题一例
浏览:3470次 出处信息
最近用xdebug观察线上程序的运行时间统计,发现往日里跑起来像飞的memcache居然是系统中拖后腿的耗时大户,连接时间特长。
运行环境
webserver是apache + phpphp memcache extension版本是3.0.2,当时是最新的beta版...有4个memcache server可供使用代码中会利用php的Memcache::addServer依次连接四个memcache,长连接方式现象
完成四次addServer一共需要300ms以上,但是一旦连接上,获取单个item飞快,时间在3ms以下。
更可恶的问题在于,虽然执行了四次Memcache::addServer,但是实际使用的始终是最后一个memcache,这实在让人崩溃。
问题解决
使用了一点搜索技巧,在pecl.php.net上找到了类似的bug: First get slow when using multiple memcached servers
这个bug的描述如下:
We are monitoring memcached performance and noticed that when we added a second memcached via Memcache::addServer the first get request is always slower than the subsequent ones although we are using persitent memcached connections. Switching from crc32 to fnv hashing didn\'t help either. Is that delay explainable
看起来是最新的memcache extension有一些问题,尝试将这个扩展降级成最新的稳定版2.2.6,然后重启apache看看,memcache连接过慢的问题果然已经解决。
结论
吃螃蟹果然是要付出代价的。。
建议继续学习:
- 关于memcache分布式一致性hash (阅读:10694)
- Memcache分布式部署方案 (阅读:5448)
- 关于session和memcache的若干问题 (阅读:4283)
- Memcache源代码分析之数据存储 (阅读:3907)
- Memcache mutex设计模式 (阅读:3760)
- 关于Memcache长连接自动重连的问题 (阅读:3672)
- Memcache协议的学习 (阅读:3620)
- Memcache源代码分析之网络处理 (阅读:3609)
- memcache的几点注意 (阅读:3473)
- memcache连接慢又一例 (阅读:3308)
QQ技术交流群:445447336,欢迎加入!
扫一扫订阅我的微信号:IT技术博客大学习
扫一扫订阅我的微信号:IT技术博客大学习
文章信息
- 作者:Volcano 来源: 某人的栖息地
- 标签: memcache
- 发布时间:2009-10-26 23:09:54
建议继续学习
近3天十大热文
- [54] IOS安全–浅谈关于IOS加固的几种方法
- [52] android 开发入门
- [52] 如何拿下简短的域名
- [51] 图书馆的世界纪录
- [49] Go Reflect 性能
- [49] Oracle MTS模式下 进程地址与会话信
- [47] 【社会化设计】自我(self)部分――欢迎区
- [46] 读书笔记-壹百度:百度十年千倍的29条法则
- [36] 程序员技术练级攻略
- [29] 视觉调整-设计师 vs. 逻辑