赞
踩
在linux系统中一切皆文件,每当有一个tcp连接建立,那么就会打开一个文件描述符。在Linux系统中,文件描述符打开的个数是有限制的,当超过这个限制的时候内核就会跑出too many open files异常。
linux上能打开的最大文件数量受三个参数限制,分别是:
fs.file-max (系统级别参数):该参数描述了整个系统可以打开的最大文件数量。但是root用户不会受该参数限制(比如:现在整个系统打开的文件描述符数量已达到fs.file-max ,此时root用户仍然可以使用ps、kill等命令或打开其他文件描述符)
soft nofile(进程级别参数):限制单个进程上可以打开的最大文件数。只能在Linux上配置一次,不能针对不同用户配置不同的值
fs.nr_open(进程级别参数):限制单个进程上可以打开的最大文件数。可以针对不同用户配置不同的值
这三个参数之间有互相耦合的关系,配置是需要注意以下三点:
TCP连接从根本上来看其实是客户端和服务器同时维护的一组socket内核对象(就是四元组)。如果只以ESTABLISH状态的连接来算(只是建立连接,但是不收发数据也不处理业务逻辑),一台服务器支持多少连接?以4G内存的服务器为例子。
一条ESTABLISH状态的连接大约消耗【3.3KB内存】,那么通过计算得出【可以建立100w+的TCP连接】,当然这里理论计算的数量,实际不可能有这么多,因为服务器还需要提供计算以及收发数据的能力这些都是要消耗内存的。
服务器开销的大头往往不是连接本身,而是处理具体业务。
客户端与服务器建立连接服务会消耗客户端的一个端口,一台机器的端口有65535个。
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。