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

时间:2020-03-05 18:45:02  来源:igfitidea点击:

运行我的应用程序时,有时会出现关于"打开太多文件"的错误。

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

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

解决方案

回答

我们总是可以尝试执行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引导脚本。

回答

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

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

*硬nofile 10000

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

ulimit -n 10000

没有权限错误。