首页
学习
活动
专区
工具
TVP
发布
社区首页 >问答首页 >如何更改Linux中打开文件的数量限制?

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

Stack Overflow用户
提问于 2008-08-29 16:14:25
回答 4查看 535K关注 0票数 211

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

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

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

EN

回答 4

Stack Overflow用户

回答已采纳

发布于 2008-08-29 16:30:04

你可以试着做一个ulimit -n 2048。这将仅重置当前shell的限制,并且您指定的数量不得超过硬限制

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

代码语言:javascript
复制
set rlim_fd_max = 166384
set rlim_fd_cur = 8192

在OS X上,必须在/etc/sysctl.conf中设置相同的数据。

代码语言:javascript
复制
kern.maxfilesperproc=166384
kern.maxfiles=8192

在Linux下,这些设置通常位于/etc/security/limits.conf中。

有两种限制:

软限制只是当前强制执行的limits

  • hard限制标记的最大值,该值不能通过设置软限制

来超过

软限制可以由任何用户设置,而硬限制只能由root用户更改。限制是进程的属性。它们是在创建子进程时继承的,因此应该在初始化脚本中的系统初始化期间设置系统范围的限制,并且应该在用户登录期间设置用户限制,例如使用pam_limits。

机器启动时通常会设置默认值。因此,即使您可以在单个shell中重置ulimit,您也可能会发现它在重新引导时重置回以前的值。如果您想要更改缺省值,您可能希望grep引导脚本以获取现有的ulimit命令。

票数 160
EN

Stack Overflow用户

发布于 2009-05-28 21:44:24

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

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

* hard nofile 10000

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

ulimit -n 10000

没有权限错误。

票数 108
EN

Stack Overflow用户

发布于 2011-11-27 19:39:02

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

代码语言:javascript
复制
webuser hard nofile 64000

然后以webuser身份登录

代码语言:javascript
复制
su - webuser

2)编辑以下两个webuser文件

通过运行以下命令追加.bashrc和.bash_profile文件

代码语言:javascript
复制
echo "ulimit -n 64000" >> .bashrc ; echo "ulimit -n 64000" >> .bash_profile

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

代码语言:javascript
复制
$ ulimit -a | grep open
open files                      (-n) 64000

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

票数 37
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/34588

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档