Linux对外连接端口数限制

这两天做压力测试,发现了一个问题,当模拟TCP client对外发起连接数达到28000左右时,开始大量抛如下异常:

    java.net.BindException: Cannot assign requested address

    at sun.nio.ch.Net.connect0(Native Method)

    at sun.nio.ch.Net.connect(Net.java:364)

    at sun.nio.ch.Net.connect(Net.java:356)

    at sun.nio.ch.UnixAsynchronousSocketChannelImpl.implConnect(UnixAsynchronousSocketChannelImpl.java:326)

    at sun.nio.ch.AsynchronousSocketChannelImpl.connect(AsynchronousSocketChannelImpl.java:195)

    at com.aliyun.talk.mon.stack.comm.AsyncConnection.connect(AsyncConnection.java:85)

    研究发现,Linux对外的随机分配端口是由一定限制的,理论上单机对外的端口最大值为65535,除去一些保留端口和被占用端口外,也应该在6W左右,但实际上单机建立对外连接时,默认不超过28232个连接。

    执行以下命令就很清楚原因了:

    $ cat /proc/sys/net/ipv4/ip_local_port_range

输出结果为:

    32768   61000

    这就是Linux随机分配端口的范围,如果在该范围内有被占用的端口,那么连接数肯定小于28232.如果想更改这个范围,可以执行以下命令:

    # echo "10000 65535" > /proc/sys/net/ipv4/ip_local_port_range




      本文转自Tenderrain 51CTO博客,原文链接http://blog.51cto.com/tenderrain/1753399:,如需转载请自行联系原作者


上一篇:阿里云身份管理与访问控制之信任管理: 角色扮演, 临时身份和安全令牌


下一篇:一个正在被API驱动的互联网时代