在运行我的应用程序时,我有时会收到关于打开的文件过多
的错误。
运行 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,您也可能会发现它会在重新启动时重置回之前的值。如果要更改默认值,您可能需要 grep 引导脚本以获取存在 ulimit 命令。
关于linux - 如何更改 Linux 中打开文件的数量限制?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/34588/