当前位置:  开发笔记 > 编程语言 > 正文

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

如何解决《如何更改Linux中的打开文件数限制?》经验,为你挑选了4个好方法。

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

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

编辑 ulimit -n 2048权限错误中的结果.



1> hoyhoy..:

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

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

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启动脚本.


你能告诉我如何在windows中使用它吗?

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`.

3> 小智..:

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

webuser hard nofile 64000

然后以webuser身份登录

su - webuser

2)编辑以下两个webuser文件

通过运行附加.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中的行从'hard'更改为'soft',它应该成为新的默认值,而不需要更改bash配置文件.

4> 小智..:

如果您的某些服务陷入ulimits,有时更容易将适当的命令放入服务的init-script中.例如,当Apache报告时

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

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

推荐阅读
落单鸟人
这个屌丝很懒,什么也没留下!
DevBox开发工具箱 | 专业的在线开发工具网站    京公网安备 11010802040832号  |  京ICP备19059560号-6
Copyright © 1998 - 2020 DevBox.CN. All Rights Reserved devBox.cn 开发工具箱 版权所有