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

 

一个精简版的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

 

相关文章:

  • 2021-07-19
  • 2022-12-23
  • 2021-05-18
  • 2022-12-23
  • 2022-12-23
  • 2021-07-06
  • 2022-12-23
  • 2022-12-23
猜你喜欢
  • 2022-03-08
  • 2021-07-19
  • 2022-12-23
  • 2021-09-16
  • 2022-12-23
  • 2021-09-19
  • 2022-01-18
相关资源
相似解决方案