too many open files错误到底可以通过什么参数控制

在运行程序时,程序代码本身没有出错,但是还是报了一个 too many open files,经过查找后发现是linux系统本身对进程可以打开的文件有一个数量的限制。下面是解决方法

一 ulimit命令

Linux对于每个用户,系统限制其最大进程数。为提高性能,可以根据设备资源情况,设置各linux 用户的最大进程数。

参数

-a:显示目前资源限制的设定; 
-c :设定core文件的最大值,单位为区块; 
-d <数据节区大小>:程序数据节区的最大值,单位为KB;
-f <文件大小>:shell所能建立的最大文件,单位为区块;
-H:设定资源的硬性限制,也就是管理员所设下的限制;
-m <内存大小>:指定可使用内存的上限,单位为KB; 
-n <文件数目>:指定同一时间最多可开启的文件数; 
-p <缓冲区大小>:指定管道缓冲区的大小,单位512字节; 
-s <堆叠大小>:指定堆叠的上限,单位为KB; 
-S:设定资源的弹性限制; 
-t :指定CPU使用时间的上限,单位为秒; 
-u <程序数目>:用户最多可开启的程序数目;
 -v <虚拟内存大小>:指定可使用的虚拟内存上限,单位为KB。

所以我们可以通过ulimit -n查看到当前shell里最多可开启的文件数。一般默认是1024.

很明显,在生产环境中,这个默认值是会慢慢超过的,也就产生了too many open files这个问题,现在我们需要去修改这个参数。

1.临时方法 shell级限制

ulimit -n xxx

这种方式可以在本次连接中有效,下次重新登录服务器时就会失效

2.长久方法 用户级限制

通过修改 /etc/security/limits.conf实现

vi /etc/security/limits.conf

在文件末尾添加:

* soft nofile 4096 
* hard nofile 4096

这里添加了两行四列,分别对应下面四个参数说明:

username|@groupname type resource limit

用户 类型 资源 限制

所以,在文件末尾添加的两句命令就是:

任何用户  软件  任何文件   4096个文件
任何用户  硬件  任何文件   4096个文件

修改完毕后,直接退出本次服务器连接 ,重新登录一下就可,不必重启服务器。

补充

1./proc/sys/fs/file-max限制不了/etc/security/limits.conf

2.只有root用户才有权限修改/etc/security/limits.conf

3.对于非root用户, /etc/security/limits.conf会限制ulimit -n,但是限制不了root用户

4.对于非root用户,ulimit -n只能越设置越小,root用户则无限制

5.任何用户对ulimit -n的修改只在当前环境有效,退出后失效,重新登录新来后,ulimit -n由limits.conf决定

6.如果limits.conf没有做设定,则默认值是1024

7.当前环境的用户所有进程能打开的最大问价数量由ulimit -n决定

©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • 引言 当修改一个Linux系统参数或限制,比如文件打开数时,之前用到过的方式有ulimit、limits.conf...
    bluexiii阅读 11,434评论 0 5
  • Ubuntu的发音 Ubuntu,源于非洲祖鲁人和科萨人的语言,发作 oo-boon-too 的音。了解发音是有意...
    萤火虫de梦阅读 100,223评论 9 468
  • 今天发现了一个学习美语的好网站:www.voachinese.com Let's Learn English is...
    麦金阅读 4,108评论 0 0
  • 中国一直是以龙为图腾的,并且我们也自称是龙的传人;拿破仑说,远东有头雄狮,无论是龙还是雄狮,都很强大,但毕竟也会有...
    唐公子1阅读 1,445评论 0 1
  • 昨天的效率降低了很多,也许是周五了吧,心灵需要休息,拖延就显得相对 严重,周五你应该干什么,或许应该出去码头走一...
    律人阅读 2,635评论 0 0

友情链接更多精彩内容