Too many open files的四种解决办法

  1. 单个进程打开文件句柄数过多
  • ulimit -a :查看单进程可以打开最大文件句柄数,子进程默认继承父进程的限制
  • cat /proc//limits:查看进程可以打开的文件句柄数
  • 修改/etc/security/limits.conf文件中nofile,通过切换用户或者重新登陆使配置生效
  • prlimit --pid ${pid} --nofile=102400:102400: 动态修改进程的打开文件句柄数限制
  1. 操作系统打开的文件句柄数过多
  • 动态修改:
echo 100000000 > /proc/sys/fs/file-max

  • 永久修改:
 /etc/sysctl.conf
  1. systemd对该进程进行了限制
    修改该进程的service文件
    下面添加“LimitNOFILE=655360”来实现,使用systemctl daemon-reload来使该配置生效。
  2. inotify达到上限
    notify是linux提供的一种监控机制,可以监控文件系统的变化。该机制受到2个内核参数的影响:“fs.inotify.max_user_instances”和“fs.inotify.max_user_watches”,其中“fs.inotify.max_user_instances”表示每个用户最多可以创建的inotify instances数量上限,“fs.inotify.max_user_watches”表示么个用户同时可以添加的watch数目
    当其他三种都无效,尝试这种办法。修改/etc/sysctl.conf,执行sysctl -p
  • 0
    点赞
  • 0
    评论
  • 0
    收藏
  • 一键三连
    一键三连
  • 扫一扫,分享海报

相关推荐
©️2020 CSDN 皮肤主题: 黑客帝国 设计师:白松林 返回首页
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、C币套餐、付费专栏及课程。

余额充值