如何更改Linux中打开文件的数量限制?[关闭]


194

运行我的应用程序时,有时会出现关于的错误too many files open

运行ulimit -a报告该限制为1024。如何将限制增加到1024以上?

编辑 ulimit -n 2048导致权限错误。



我只是在Centos 7上经历了这一点(在RHEL上也是如此),并写了一篇博客文章来介绍它,因为即使在所有这些文章上我也遇到了很多麻烦:coding-stream-of-ogniness.com/2018/12/21/…。通常,与打开的文件一起,您需要增加实际上位于多个设置文件中的nproc ...,如果您使用具有自己单独设置的systemd / systemctl。有点坚果。
约翰·汉弗莱斯

如果您在Linux上使用VSCode,此解决方法可能会有所帮助:stackoverflow.com/a/55027686/1190948
Juri Sinitson

Answers:


153

您可以随时尝试执行ulimit -n 2048。这只会重置当前shell的限制,并且您指定的数字不得超过硬限制

每个操作系统在配置文件中都有不同的硬限制设置。例如,可以从/ etc / system引导时设置Solaris上的硬打开文件限制。

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您的引导脚本。


4
你能告诉我如何在Windows中使用它吗?
2015年

@hoyhoy我可以将其更改为,20484500为什么不更改?看到这个
alhelal

@GaneshKrishnan您提到的linux文件中要添加什么?
阿维尔·桑杰

@Pritam Windows没有任何ulimit。您必须指定正在使用的内容(例如WSL,Cygwin)。
Melebius

99

如果您使用的是Linux,并且遇到权限错误,则需要提高/etc/limits.confor /etc/security/limits.conf文件中的允许限制(文件所在的位置取决于您的特定Linux发行版)。

例如,要允许计算机上的任何人将打开的文件数提高到10000,请在limits.conf文件中添加一行。

* hard nofile 10000

然后注销并重新登录到系统,您应该能够执行以下操作:

ulimit -n 10000

没有权限错误。


6
注:通配符并不适用于root用户。您必须指定root hard nofile 10000是否要调整root限制。
约书亚·品特

1
@JoshPinter哈哈,我刚刚花了大约3个小时左右的时间遍历每个教程中有关如何更改的内容ulimit,最后发现我以root用户身份登录。这就是为什么我一直看到1024英寸的原因ulimit -a。我改变了野外护理,并在*里面加了东西limits.conf。现在一切都很好,(我使用ssh键不用担心:P)-谢谢!!!
NiCk Newman

1
@NiCkNewman我很高兴你在笑它!对于程序员/ sysops人来说,这是一个很好的特征。我做过同样的事情,并不那么快乐。很高兴它有所帮助!:)
约书亚·品特

补充:您可能还会在此目录中找到一个配置:/etc/security/limits.d/
WaldemarWosiński16年

2
我第一次打开/etc/security/limits.conf,注意到那里的所有内容都被注释掉了。那么“ hard nofile”的默认值是什么?
ka3ak

36

1)将以下行添加到 /etc/security/limits.conf

webuser hard nofile 64000

然后以网络用户身份登录

su - webuser

2)为网络用户编辑以下两个文件

通过运行附加.bashrc和.bash_profile文件

echo "ulimit -n 64000" >> .bashrc ; echo "ulimit -n 64000" >> .bash_profile

3)注销,然后重新登录并验证更改是否正确:

$ ulimit -a | grep open
open files                      (-n) 64000

就是这样,他们繁荣起来,繁荣起来。


9
如果您将limits.conf中的行从“硬”更改为“软”,则它应成为新的默认值,并且不需要更改bash配置文件。
RishiD

似乎您正在重复执行其他步骤。仅在所有会话中设置限制都将与配置文件相同。
Eddie

6

如果您的某些服务陷入了ulimit限制,则有时将适当的命令放入服务的init脚本会更容易。例如,当Apache正在报告时

[警告](11)资源暂时不可用:apr_thread_create:无法创建工作线程

尝试把ulimit -s unlimited/etc/init.d/httpd。这不需要重启服务器。

By using our site, you acknowledge that you have read and understand our Cookie Policy and Privacy Policy.
Licensed under cc by-sa 3.0 with attribution required.