【问题标题】:How do I change the number of open files limit in Linux? [closed]如何更改 Linux 中打开文件的数量限制? [关闭]
【发布时间】:2010-09-07 06:26:47
【问题描述】:

在运行我的应用程序时,我有时会收到关于 too many files open 的错误。

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

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

【问题讨论】:

标签: linux


【解决方案1】:

你总是可以尝试做一个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,您也可能会发现它会在重新启动时重置回之前的值。如果您想更改默认值,您可能需要 grep 启动脚本以获取存在 ulimit 命令。

【讨论】:

  • 你能告诉我如何在windows中使用它吗?
  • @hoyhoy 我可以将其更改为2048,但不能更改为4500,为什么? see this
  • @GaneshKrishnan 在您提到的 linux 文件中添加什么?
  • @Pritam Windows 没有任何ulimit。您必须指定您使用的是什么(例如 WSL、Cygwin)。
【解决方案2】:

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

例如,要允许机器上的任何人将打开文件的数量增加到 10000 个,请将该行添加到 limits.conf 文件中。

* hard nofile 10000

然后注销并重新登录到您的系统,您应该可以这样做:

ulimit -n 10000

没有权限错误。

【讨论】:

  • 注意:通配符适用于root 用户。如果要调整 root 限制,则必须指定 root hard nofile 10000
  • @JoshPinter 哈哈,我刚刚花了 3 个小时左右的时间阅读了有关如何更改 ulimit 的每个教程,最后发现我是以 root 身份登录的。这就是为什么我一直在ulimit -a 中看到 1024。我更改了 wildcare,并在 limits.conf 中添加了一个 *。现在一切都很好,(我使用 ssh 密钥,别担心 :P)——谢谢!!!
  • @NiCkNewman 我很高兴你笑了!这是程序员/系统操作人员的一个好特质。我做了同样的事情,但不是那么愉快。很高兴它有帮助! :)
  • 补充:您还可以在此目录中找到一个配置:/etc/security/limits.d/
  • 我第一次打开 /etc/security/limits.conf 并注意到那里的所有内容都被注释掉了。那么“hard nofile”的默认值是多少呢?
【解决方案3】:

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

就是这样,他们轰隆隆,轰隆隆。

【讨论】:

  • 如果您将 limits.conf 中的行从“硬”更改为“软”,它应该成为新的默认值,并且不需要更改 bash 配置文件。
  • 您似乎在重复一个额外的步骤。单独设置限制与配置文件的作用相同,但适用于所有会话。
【解决方案4】:

如果您的某些服务拒绝使用 ulimit,有时将适当的命令放入服务的初始化脚本中会更容易。例如,当 Apache 报告时

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

尝试将ulimit -s unlimited 放入/etc/init.d/httpd。这不需要重新启动服务器。

【讨论】:

    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2012-10-01
    • 2014-12-07
    • 2022-01-25
    • 2016-05-31
    • 1970-01-01
    相关资源
    最近更新 更多