运行我的应用程序时,我有时会收到有关too many files open
的错误。
运行ulimit -a
报告限制为1024.如何将限制增加到1024以上?
修改
ulimit -n 2048
会导致权限错误。
答案 0 :(得分:147)
您可以随时尝试ulimit -n 2048
。这只会重置当前shell的限制,并且您指定的数量不得超过硬限制
每个操作系统在配置文件中都有不同的硬限制设置。例如,Solaris上的硬打开文件限制可以在/ etc / system启动时设置。
set rlim_fd_max = 166384
set rlim_fd_cur = 8192
在OS X上,必须在/etc/sysctl.conf中设置相同的数据。
kern.maxfilesperproc=166384
kern.maxfiles=8192
在Linux下,这些设置通常位于/etc/security/limits.conf。
有两种限制:
任何用户都可以设置软限制,而硬限制只能由root更改。 限制是流程的属性。创建子进程时会继承它们,因此应在init脚本的系统初始化期间设置系统范围限制,并且应在用户登录期间设置用户限制,例如使用pam_limits。
机器启动时经常会设置默认值。因此,即使您可能在单个shell中重置ulimit,您可能会发现它在重新引导时重置为先前的值。如果要更改默认值,可能需要为启动ulimit命令grep启动脚本。
答案 1 :(得分:92)
如果您正在使用Linux并且您收到了权限错误,则需要在/etc/limits.conf
或/etc/security/limits.conf
文件中提高允许的限制(文件所在的位置取决于您的特定Linux发行版) 。
例如,要允许计算机上的任何人将其打开文件的数量提高到10000,请将该行添加到limits.conf
文件中。
* hard nofile 10000
然后注销并重新登录到您的系统,您应该能够:
ulimit -n 10000
没有权限错误。
答案 2 :(得分:35)
1)将以下行添加到/etc/security/limits.conf
webuser hard nofile 64000
然后以webuser身份登录
su - webuser
2)编辑以下两个webuser文件
运行
附加 .bashrc和.bash_profile 文件echo "ulimit -n 64000" >> .bashrc ; echo "ulimit -n 64000" >> .bash_profile
3)注销,然后重新登录并验证更改是否正确:
$ ulimit -a | grep open
open files (-n) 64000
多数民众赞成,繁荣,繁荣。
答案 3 :(得分:6)
如果您的某些服务涉及到ulimits,有时更容易将适当的命令放入服务的init脚本中。例如,当Apache报告时
[alert](11)资源暂时不可用:apr_thread_create:无法创建工作线程
尝试将ulimit -s unlimited
放入/etc/init.d/httpd
。这不需要重新启动服务器。