Nginx HttpMemcModule和直接访问memcached效率对比测试

2025-05-26 0 69

测试环境:



测试客户机A: HP DL380G4,2个双核CPU,4G Ram,2块10k RPM SAS盘做raid 1,ext3

Nginx所在服务器B:DELL R710,E5620 * 2,32G Ram,6块盘15K RPM SAS盘做raid 1+0,xfs

Memcached所在服务器C:DELL R710,E5620 * 2,32G Ram,6块盘15K RPM SAS盘做raid 5,ext4

Nginx设置:keepalive 8192

Php fpm设置:listen.backlog = -1

memcached启动参数:memcached -d -m 24576 -p 12000 -c 10240



内核参数:


net.ipv4.tcp_tw_recycle = 0

net.ipv4.tcp_tw_reuse = 0

net.ipv4.tcp_timestamps = 1



关于这几个内核参数对应的解释可参考资料:2.12. Reduce TCP performance spikes



测试方案:



使用php连接本地nginx代理,存取远程memcached数据;

使用php直接连接远程memcached服务器;

从测试客户端用ab发起并发测试;

并发线程从64开始,直到2048,分别是64的N倍;

每种并发模式都进行5轮测试,最后取平均值;

存储在memcached中的key长度96个字符,value长度400字符,总是随机生成;



测试结果:

Nginx HttpMemcModule和直接访问memcached效率对比测试Nginx HttpMemcModule和直接访问memcached效率对比测试

Nginx HttpMemcModule和直接访问memcached效率对比测试Nginx HttpMemcModule和直接访问memcached效率对比测试

结论及建议:

Php程序通过HttpMemcMC访问memcache和直接访问memcached的效率并没有太多损失;采用php直接访问memcached,失败的次数相比通过HttpMemcMC有较大增加,应该是HttpMemcMC在keepalive方面更有优势;后续会在进行一次测试,调整nginx、php及内核相关参数,再做对比;本次测试没有和正常的http请求混在一起对比,测试结果不具备绝对参考价值;

单从本次测试结果来看,HttpMemcMC值得拥有



结果结果更新:



调整上述几个内核参数:



net.ipv4.tcp_tw_recycle = 1net.ipv4.tcp_tw_reuse = 1net.ipv4.tcp_timestamps = 1



通过调整内核参数,调整tcp连接复用性提高tcp效率,新的测试结果如下:

Nginx HttpMemcModule和直接访问memcached效率对比测试Nginx HttpMemcModule和直接访问memcached效率对比测试Nginx HttpMemcModule和直接访问memcached效率对比测试 Nginx HttpMemcModule和直接访问memcached效率对比测试

备注:由于2次测试案例中,每并发线程请求数不一样,所以你会发现两边的数据无法直接对比,这是我的失误,抱歉。



补充小结:



调整完内核后:

1. 可以发现,HttpMemc的平均效率只有NativeMC 72.62%;

2. 调整内核tcp参数对提升tcp效率非常有帮助,Failed requests次数完全为0;

3. 由于可以提高memcached连接复用率以及对程序透明的好处,即便HttpMemc性能不如NativeMC,损失并不是非常厉害,仍然是可以接受的;

收藏 (0) 打赏

感谢您的支持,我会继续努力的!

打开微信/支付宝扫一扫,即可进行扫码打赏哦,分享从这里开始,精彩与您同在
点赞 (0)

声明:本站所有文章,如无特殊说明或标注,均为本站原创发布。任何个人或组织,在未征得本站同意时,禁止复制、盗用、采集、发布本站内容到任何网站、书籍等各类媒体平台。如若本站内容侵犯了原著者的合法权益,可联系我们进行处理。

快网idc优惠网 建站教程 Nginx HttpMemcModule和直接访问memcached效率对比测试 https://www.kuaiidc.com/53701.html

相关文章

发表评论
暂无评论