美文网首页Liiiinux服务器分布式&高可用
Linux服务器性能的重要指标:打开文件数的限制

Linux服务器性能的重要指标:打开文件数的限制

作者: 编程无界 | 来源:发表于2018-07-26 07:47 被阅读78次

    文件是Linux系统中的一切事物的存在形式,计算机中的数据和硬件都是通过文件的形式进行管理,Linux的文件主要有普通文件、文件夹、设备文件、链接文件、管道文件、套接字文件(数据通信的接口)等类型,Linux 中的各种事物比如像文档、文件夹、键盘、监视器、硬盘、可移动媒体设备、打印机、调制解调器、虚拟终端等等都是定义在文件系统空间下的字节流。

    因此在Linux系统上的web程序,在进行TCP连接时,系统为每个TCP连接创建一个socket句柄,而每个句柄也是一个文件句柄,所以web程序对文件的操作情况,是影响到服务器性能的重要指标,像网站在高流量高并发的场景下出现"Too many open files"的异常就是因为打开的文件数超过限制,而程序中对资源(包括图片、音视频资源)、网页、以及接口的请求在Linux系统里的表现为对文件的访问,如果打开文件数超出了系统限制(系统级和用户级)的数量,就会拒绝接下来的文件访问当前用户级的文件数限制,可以通过 ulimit -n 来查看,如图: 

    而系统级别的文件数限制,则通过sysctl -a来查看,如下图: 

    一般系统最大文件数会根据硬件资源计算出来的,如果强行需要修改最大打开文件数可以通过ulimit -n 10240来修改,当这种方式只对当前进程有效,如果需要永久有效则需要修改/etc/security/limits.conf(重启系统生效),如下图: 

    其中:

    root :指定用户,如对所有用户,则写 *

    soft:软限制

    hard:硬件限制

    nofile 是代表最大文件打开数

    除此之外,下面是一些打开文件数操作相关的指令,仅供参考:

    1、查看所有进程的文件打开数:

    lsof |wc -l 

    2、查看某个进程打开的文件数:

    lsof -p pid |wc -l

    3、查看系统中各个进程分别打开了多少句柄数:

    lsof -n|awk ‘{print $2}’|sort|uniq -c|sort -nr|more

    觉得本文对你有帮助?请分享给更多人

    关注「编程无界」,提升装逼技能

    相关文章

      网友评论

      本文标题:Linux服务器性能的重要指标:打开文件数的限制

      本文链接:https://www.haomeiwen.com/subject/iejvmftx.html