本文共 1354 字,大约阅读时间需要 4 分钟。
在SUSE Linux下部署应用的时候,有时会遇到“Socket/File: Can’t open so many files”的问题,这其实是因为SUSE Linux系统的文件句柄限制造成的,一般系统默认都是允许打开1024个文件,作为一台生产环境的应用服务器,是很容易就达到这个默认值的,因此我们需要把这个值改大一些。 文件句柄释义:在文件I/O中,要从一个文件读取数据,应用程序首先要调用操作系统函数并传送文件名,并选一个到该文件的路径来打开文件。该函数取回一个顺序号,即文件句柄(file handle),该文件句柄对于打开的文件是唯一的识别依据。要从文件中读取一块数据,应用程序需要调用函数ReadFile,并将文件句柄在内存中的地址和要拷贝的字节数传送给操作系统。当完成任务后,在通过调用系统函数来关闭该文件。
下面我们看如何修改:
1、先查看系统默认值
3、ulimit其实就是对用户和单一程序的限制,我们再看一下系统总限制: 查看系统总限制命令: #cat /proc/sys/fs/file-max 查看整个系统目前使用的文件句柄数量命令: #cat /proc/sys/fs/file-nr
如果要修改file-max和file-nr的值,需要通过vi /etc/sysctl.conf进行编辑修改,使用sysctl -p使其生效。
对于一般的应用来说(Apache、系统进程)1024完全足够使用,但是对于squid、mysql、java等单进程处理大量请求的应用来说就不够用了。那么如何知道当前进程打开了多少个文件句柄呢?我们可以通过这个来查看:
#lsof -n |awk '{print $2}'|sort|uniq -c |sort -nr|more左边一列是打开的文件句柄数量,第二列是进程ID号。如果系统并发特别大,文件句柄数很有可能会超过1024,这时候我们就必须要调整系统参数,以适应实际应用的变化。
补充:
查看某个进程开了那些句柄: #lsof -p pid 查看某个进程开了多少个句柄:#lsof -p pid |wc -l看某个文件/目录被什么进程占用了,显示已打开该目录或文件的所有进程信息: #lsof path/filename转载地址:http://emkcx.baihongyu.com/