异步IO的并发能力:backlog的配置很重要

今天中午正准备完工的时候,发现一个让人抓狂的问题。

 

一个精简版的AIO应用理论上应该比一个完整版的AIO应用并发能力高一些(因为完整版的事务处理复杂一些),在同一台机器上测试。

但测试结果显示,精简版的并发能力还不如完整版的AIO应用。

 

花了一个多小时,终于找到原因:原来是backlog的设置不同。

 

关于网络编程中的backlog参数说明:

http://dola.xinfan.org/?p=110

 

精简版的相关代码:

int backlog = 100; 
asynServerChannel.bind(new InetSocketAddress(port), backlog);

 

完整版的相关代码:

int backlog = 200; 
asynServerChannel.bind(new InetSocketAddress(port), backlog);

可以看出,主要是 backlog的设置不一样,导致精简版的AIO比完整版的AIO还低一些。

我把精简版的AIO中的backlog设置为200后,再用ab(压力测试),终于可以比完整版的AIO并发能力高一些了。

 

2013-01-12

 

posted @ 2015-06-18 06:50  personnel  阅读(576)  评论(0编辑  收藏  举报
友情链接:图片批量处理工具 gif动态图制作工具 制作电子相册 图片排版工具 制作淘宝主图视频 MKScript 鼠标键盘自动化脚本语言