211

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

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

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

4

4 回答 4

160

你总是可以尝试做一个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 命令。

于 2008-08-29T16:30:04.443 回答
108

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

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

* hard nofile 10000

然后注销并重新登录到您的系统,您应该能够:

ulimit -n 10000

没有权限错误。

于 2009-05-28T21:44:23.743 回答
38

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

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

于 2011-11-27T11:39:01.863 回答
7

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

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

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

于 2012-03-01T18:38:03.340 回答