很早微博上一直讨论比较多的问题,这里转载个知乎的答案:单机单网卡最大tcp长连接数真的是65535吗?
- 作者:许怀远
链接:https://www.zhihu.com/question/66553828/answer/244313925
来源:知乎
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。
TCP四元组(quadruple)的概念,就算培训班出来的也听说过吧?不做解释了。(源IP,源port,目标IP,目标port),最大能有多少连接数,全看这4个参数。从服务端accept客户端的角度,IPv4为例源IP可以有几十亿个,不同客户端都可以connect过来源port理论上65535个,因为local port range缘故,一般只有一半左右目标IP,单网卡也可以多IP,上限多少看操作系统限制目标port理论上65535个,由于port range,一般也只有一半左右四个因子相乘,可以有超过万亿级的连接数,当然只是理论上的一般我们对外的服务,会引入更多的限制,例如HTTP,目标端口是固定的,目标IP通过DNS负载均衡可以有多个,但是一般单机不会这么做。尽管多了限制,上限还是很高啊,仅源IP和源端口相乘就比65535高不知道多少个数量级。除此之外,操作系统层面还有更多限制,比如进程fd上限,32位系统还有内存限制,64位系统单机物理内存也是有限的,现在最大的配置,内存也就T级,还没有到P级。现实一点,一般的服务器,比如阿里云上能买得到的配置,能承受多少连接数呢?100万级是很容易做到的,再往高里去就不是hello world这么容易了。就算傻傻的开多线程,一个线程一个连接,也远远不止65535个啊。
- 陈硕大神的一个相关文章: