1. 增加最大文件描述符限制
可以通过在系统文件/etc/security/limits.conf中添加如下内容来增加最大文件描述符限制:
* soft nofile 65535
* hard nofile 65535
然后重启系统生效。
2. 减少已开启的文件描述符
可以通过命令“lsof -u”查看当前用户已经开启的文件描述符数量,然后逐个关闭不需要的文件,以降低已开启的文件描述符数量。
3. 优化应用程序代码
如果应用程序存在大量打开文件描述符的 *** 作,可以考虑优化代码,减少打开文件描述符的数量。可以使用资源池技术或者标准 I/O 库等方法实现。
最大值是系统相关的,linux shell 输入如下命令就知道,其中的“-n: file descriptors”就是最大限制值。# ulimit -a
-f: file size (blocks) unlimited
-t: cpu time (seconds) unlimited
-d: data seg size (kb) unlimited
-s: stack size (kb)8192
-c: core file size (blocks)0
-m: resident set size (kb) unlimited
-l: locked memory (kb) 64
-p: processes 128
-n: file descriptors 1024
-v: address space (kb) unlimited
-w: locks unlimited
-e: scheduling priority0
-r: real-time priority 0
1. 端口号限制?
首先, 不存在 由于端口号限制 65535 个的说法,因为目标端的ip和端口是无限的。
当然, Linux 对可使用的端口范围是有具体限制的,具体可以用如下命令查看:
这个限制可以 vim /etc/sysctl.conf 这个文件进行修改,我们在这个文件里添加一行记录:
保存好后执行 sysctl -p /etc/sysctl.conf 使其生效。
2. 文件描述符的限制?
修改单个进程可打开的最大文件描述符限制为100,可以这样:
理论上文件描述符可以设置的足够大。
3. 线程数的限制?
每建一个TCP连接就创建一个线程的方式,是最传统的多线程并发模型,早期的 *** 作系统也只支持这种方式。
C10K 问题: 当服务器连接数达到 1 万且每个连接都需要消耗一个线程资源时, *** 作系统就会不停地忙于线程的上下文切换,最终导致系统崩溃。
但是:
现在的 *** 作系统都支持 IO 多路复用的方式,简单说就是一个线程可以管理多个 TCP 连接的资源,这样就可以用少量的线程来管理大量的 TCP 连接了。
4. 内存的限制?
这个错误叫内存溢出,每个TCP连接本身,以及这个连接所用到的缓冲区,都是需要占用一定内存的
5. CPU的限制?
6. 总结一下,创建tcp连接需要的资源:
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)