• 解决Too many open files思路


    一、产生原因
    too many open files是Linux系统中常见的错误,从字面意思上看就是说程序打开的文件数过多,不过这里的files不单是文件的意思,也包括打开的通讯链接(比如socket),正在监听的端口等等,所以有时候也可以叫做句柄(handle),这个错误通常也可以叫做句柄数超出系统限制。 

    二、查看程序当前打开句柄的数量

    例如,我有个tomcat中报了这个错:

    ps -ef | grep tomcat      查看pid

    lsof -p 进程id | wc -l   查看进程打开句柄的数量

    cat /proc/进程id/limits  查看进程最大能打开的文件数

    ulimit -a         单个进程默认可以打开的句柄数上限

    三、解决方法
    1、增大允许打开的文件数——命令方式
    ulimit -n 2048
    这样就可以把当前用户的最大允许打开文件数量设置为2048了,但这种设置方法在重启后会还原为默认值。 
    ulimit -n命令非root用户只能设置到4096。 
    想要设置到更大需要sudo权限或者root用户。

    2、增大允许打开的文件数——修改系统配置文件
    vim /etc/security/limits.conf  
    #在最后加入  
    * soft nofile 4096  
    * hard nofile 4096  
    或者只加入

     * - nofile 8192

    最前的 * 表示所有用户,可根据需要设置某一用户,例如

    roy soft nofile 8192  
    roy hard nofile 8192  
    注意”nofile”项有两个可能的限制措施。就是项下的hard和soft。 要使修改过得最大打开文件数生效,必须对这两种限制进行设定。 如果使用”-“字符设定, 则hard和soft设定会同时被设定。

  • 相关阅读:
    帧锁定同步算法
    为 Raft 引入 leader lease 机制解决集群脑裂时的 stale read 问题
    etcd:从应用场景到实现原理的全方位解读
    给定一个二叉搜索树(BST),找到树中第 K 小的节点
    UDP如何实现可靠传输
    理解TCP/IP三次握手与四次挥手的正确姿势
    Redis持久化
    Redis提供的持久化机制(RDB和AOF)
    redis渐进式 rehash
    redis rehash
  • 原文地址:https://www.cnblogs.com/sss-justdDoIt/p/11933448.html
Copyright © 2020-2023  润新知