修改linux的最大文件句柄数限制

修改linux的最大文件句柄数限制

对于一般的应用来说(Apache、系统进程)1024完全足够使用。但是如何象squidmysqljava等单进程处理大量请求的应用来说就有点捉襟见肘了。如果单个进程打开的文件句柄数量超过了系统定义的值,就会提到“too many files open”的错误提示。如何知道当前进程打开了多少个文件句柄呢?下面一段小脚本可以帮你查看:

lsof -n |awk '{print $2}'|sort|uniq -c |sort -nr|more

修改linux的最大文件句柄数限制的方法:

1ulimit -n 65535 

在当前session有效,用户退出或者系统重新后恢复默认值

2)修改profile文件:在profile文件中添加:ulimit -n 65535

只对当个用户有效

3)修改文件:/etc/security/limits.conf,在文件中添加:(立即生效-当前session中运行ulimit -a命令无法显示)

* soft nofile 32768 #限制单个进程最大文件句柄数(到达此限制时系统报警) 

* hard nofile 65536 #限制单个进程最大文件句柄数(到达此限制时系统报错) 

4)修改文件:/etc/sysctl.conf。在文件中添加:

fs.file-max=655350 #限制整个系统最大文件句柄数 

运行命令:/sbin/sysctl -p 使配置生效

原文

http://www.2cto.com/os/201308/238169.html

posted @ 2013-11-18 00:32  浪里飞  阅读(7820)  评论(0编辑  收藏  举报