运行我的应用程序时,有时会出现关于的错误too many files open
。
运行ulimit -a
报告该限制为1024。如何将限制增加到1024以上?
编辑
ulimit -n 2048
导致权限错误。
运行我的应用程序时,有时会出现关于的错误too many files open
。
运行ulimit -a
报告该限制为1024。如何将限制增加到1024以上?
编辑
ulimit -n 2048
导致权限错误。
Answers:
您可以随时尝试执行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您的引导脚本。
ulimit
。您必须指定正在使用的内容(例如WSL,Cygwin)。
如果您使用的是Linux,并且遇到权限错误,则需要提高/etc/limits.conf
or /etc/security/limits.conf
文件中的允许限制(文件所在的位置取决于您的特定Linux发行版)。
例如,要允许计算机上的任何人将打开的文件数提高到10000,请在limits.conf
文件中添加一行。
* hard nofile 10000
然后注销并重新登录到系统,您应该能够执行以下操作:
ulimit -n 10000
没有权限错误。
root
用户。您必须指定root hard nofile 10000
是否要调整root
限制。
ulimit
,最后发现我以root用户身份登录。这就是为什么我一直看到1024英寸的原因ulimit -a
。我改变了野外护理,并在*
里面加了东西limits.conf
。现在一切都很好,(我使用ssh键不用担心:P)-谢谢!!!
/etc/security/limits.d/
。
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
就是这样,他们繁荣起来,繁荣起来。