打开的文件过多

Author Avatar
Yoo 5月 02, 2017
  • 在其它设备中阅读本文章

首先普及几个知识:

  1. Linux下一切都是文件,包括输入输出设备、网络连接、socket、管道等
  2. 与文件打开数最相关的是文件描述符(有的人喜欢称作文件标识符,英文为file descriptor),文件打开数的实质就是文件描述符的数量
  3. 文件打开数的多少取决于系统种类、内存大小,int(语言关键字,如C99的int)长度(非负整数),以及系统管理员的设定
  4. 最大文件打开数是针对一个进程而言,即一个进程能打开的文件句柄数目是有限的,不能超过最大文件打开数
  5. ulimit命令只对当前shell有效,因此在编写Shell脚本时,如果需要并能控制文件最大打开数,则先执行“ulimit -n 文件打开数”命令,在去执行下面的内容
  6. 在Linux中被打开的文件描述符存放在/proc/PID/fd/,其中PID就是process identifier。

除了需要注意,还需要注意ulimit -v unlimited,最大可用的虚拟内存(The maximum amount of virtual memory available to the shell and, on some systems, to its children)

大多数原因是因为程序没有关闭打开的资源连接, 如RMI、数据库等连接才导致的。 当然也有可能能同时有超过Linux本身默认的文件打开数。

一、 先从Linux设置入手

(1) ulimit -a (查看资源设置情况

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
core file size (blocks, -c) 0
data seg size (kbytes, -d) unlimited
scheduling priority (-e) 0
file size (blocks, -f) unlimited
pending signals (-i) 30525
max locked memory (kbytes, -l) 64
max memory size (kbytes, -m) unlimited
open files (-n) 1024
pipe size (512 bytes, -p) 8
POSIX message queues (bytes, -q) 819200
real-time priority (-r) 0
stack size (kbytes, -s) 10240
cpu time (seconds, -t) unlimited
max user processes (-u) 1024
virtual memory (kbytes, -v) unlimited
file locks (-x) unlimited

open files默认是1024

为了使服务器重启设置还能生效, 采取永久改变的方法。
vim /etc/security/limits.conf
在文档最后添加

1
2
* soft nofile 65535
* hard nofile 65535

(2) vim /etc/pam.d/login

在文档最后添加

1
session required /lib/security/pam_limits.so

二、 程序

记得在finally语句块里面关闭资源连接, 如:

1
2
3
4
5
6
finally{
if (connector != null) {
connector.close();
}
}

一些与文件打开数相关的命令以及其他相关命令:

  1. 查看当前系统的文件打开总数(Maximum number of opened files):cat /proc/sys/fs/file-max
  2. 查看当前进程的文件打开数:lsof -p 16075 | wc –l
  3. 查看当前端口的文件打开数:lsof -i:80 | wc -l
  4. 在使用lsof之前需要注意,lsof不适合查看一个连接数很高或者数量动态变化过快的进程或端口
  5. 查看某个进程使用的文件:lsof -p 16075
  6. 查看某个端口使用的文件:lsof -i:80
  7. 查看使用某个文件的用户和程序:fuser -v /bin/bash
  8. 如果需要查看所有进程的文件打开数,如下图命令lsof |wc -l
  9. Markup一个有用的分类知识的网站:https://en.wikipedia.org/wiki/Category:Unix_file_system_technology

【参考资料】
http://blog.csdn.net/wenniuwuren/article/details/45039449
http://dgd2010.blog.51cto.com/1539422/1676843
http://www.cnblogs.com/405845829qq/p/5919495.html
http://blog.itpub.net/220284/viewspace-1024475/