• Linux基础篇-文件句柄数修改


    文件句柄数修改

    linux最大打开文件句柄数,即打开文件数最大限制,就是规定的单个进程能够打开的最大文件句柄数量(Socket连接也算在里面,默认大小1024)

    liunx中文件句柄有两个限制,一种是用户级的,一种是系统级的(也叫内核级)

    • 系统级的最大限制:
      cat /proc/sys/fs/file-max

    • 用户级的最大限制
      ulimit -n(默认是1024,像阿里云华为云这种云主机一般是65535)
       请添加图片描述

      附ulimit 参数说明:
       请添加图片描述

      查看某个进程的最大打开文件数和当前打开文件数
      先找到该进程的进程号,然后查看/proc/[pid]/limits和fd

    /proc/[pid]/limits 显示当前进程的资源限制

    /proc/[pid]/fd 是一个目录,包含进程打开文件的情况

    ps:如果要查看某个进程的线程的详细信息,/proc/[pid]/task
    查看当前系统打开的文件总数:
    lsof |wc -l
    查看某个进程打开的文件数:
    lsof -p pid |wc -l

    修改最大限制

    用户级的修改

    • 用户级修改临时生效方法:(重启后失效)
    ulimit -SHn 10000
    

    ulimit 命令分软限制和硬限制,加-H就是硬限制,加-S就是软限制。默认显示的是软限制,如果运行ulimit 命令修改时没有加上-H或-S,就是两个参数一起改变。硬限制就是实际的限制,而软限制是警告限制,它只会给出警告。

    • 用户级修改永久有效方式:
    vi /etc/security/limits.conf
    
    修改配置文件/etc/security/limits.conf,加入:
    * soft nofile 65535
    * hard nofile 65535
    echo "* soft nofile 65535" >> /etc/security/limits.conf
    echo "* hard nofile 65535" >> /etc/security/limits.conf
    * 表示所用的用户,但有的系统不认, 需要具体的用户名, 比如:
    root soft nofile 65535
    root hard nofile 65535
    12345678
    

    重新登录验证,或许reboot后验证。

    系统级的修改

    其实上面的修改都是对一个进程打开的文件句柄数量的限制,我们还需要设置系统的总限制才可以。

    假如,我们设置进程打开的文件句柄数是1024 ,但是系统总限制才500,所以所有进程最多能打开文件句柄数量500。从这里我们可以看出只设置进程的打开文件句柄的数量是不行的。所以需要修改系统的总限制才可以。

    • 系统级修改临时生效方式:
    echo  655350 > /proc/sys/fs/file-max
    
    • 系统级修改永久生效方式:
    vi /etc/sysctl.conf
    

    加入

    fs.file-max=655350
    

    系统级永久生效方式修改后,重启服务器,才能生效。

    查看系统级文件句柄修改,是否生效

    sysctl -p
    
  • 相关阅读:
    在矩池云上使用R和RStudio
    java计算机毕业设计Web端校园报修系统源码+mysql数据库+系统+lw文档+部署
    计算机视觉CV
    Hudi(三)集成Flink
    学习网络安全:记一次某网站渗透测试过程
    Oracle for Windows安装和配置——Oracle for Windows软件安装
    报考浙江工商大学2024年工商管理硕士(MBA)联考指南
    利用ChatGPT巧妙提升演讲技巧,轻松驾驭演讲舞台【文末送书-27】
    ZCMU--5162: 奖牌颁发
    智能座舱架构与芯片- (10) 音频篇 下
  • 原文地址:https://blog.csdn.net/qq_52494169/article/details/140105271