zoukankan      html  css  js  c++  java
  • 单机对外连接数 扩大

    ,当模拟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
  • 相关阅读:
    关于session
    信息查找界面
    Java8 新特性 (三)Java内置的函数式接口
    第二节:表的管理
    【LeetCode-数组】有序数组中的单一元素
    【LeetCode-字符串】一次编辑
    【LeetCode-贪心】跳跃游戏 II
    【LeetCode-数组】三个数的最大乘积
    学习进度条94
    学习进度条93
  • 原文地址:https://www.cnblogs.com/dracula/p/2428676.html
Copyright © 2011-2022 走看看