一、相关说明
二、参数修改
在linux系统中对进程可以调用的文件句柄数进行了限制,在默认情况下每个进程可以调用的最大句柄数是1024个,如果超过了这个限制,进程将无法获取新的句柄。
1、系统级
在Linux系统中,遵循一切都是文件的原则,即文件、目录、套接字、磁盘、管道等,都是以文件被对待。在打开这些资源的时候都会返回一个文件描述符即文件句柄,用来标识该资源。
Too many open files 的异常,可能是由于应用程序对资源的使用不当造成的,比如没有及时关闭Socket或数据库连接等;但也可能应用确实需要打开比较多的文件句柄,而系统本身的设置限制了这一数量。二、参数修改
在linux系统中对进程可以调用的文件句柄数进行了限制,在默认情况下每个进程可以调用的最大句柄数是1024个,如果超过了这个限制,进程将无法获取新的句柄。
1、系统级
系统级设置对所有用户有效,表示Linux内核分配的系统范围内的最大的文件句柄数
查看方式:[root@xl ~]# cat /proc/sys/fs/file-max
临时修改:
# 修改 /proc/sys/fs/file-max 文件的值,重启后失效
[root@xl ~]# echo 1000000 > /proc/sys/fs/file-max
永久修改:
# 修改 /etc/sysctl.conf文件,配置fs.file-max属性
fs.file-max = 6815755
# 配置完成后使用 sysctl -p 命令来通知系统启用这项配置
2、用户级Linux可以限制每个用户的文件句柄数
查看方式:# 查看当前有效的句柄数
[root@xl ~]# ulimit -n
临时修改:
#临时设置句柄数只对当前的会话有效,终止时便结束限制
[root@xl ~]# ulimit -HSn 65536
永久修改:
# 编辑 /etc/security/limits.conf 文件,加入一下配置
* soft nofile 4096
* hard nofile 4096
# * 代表所有用户,nofile 是代表最大文件打开数
附、查看当前进程占用文件描述符情况:
#查看进程的所有文件描述符
[root@xl ~]# lsof -p pid