记一次系统错误问题的排查经验-----sh: can‘t fork

        最近系统出现了一个莫名其妙的问题,就是运行一段时间之后出现了很多奇怪的异常现象,所以第一反应是看一下进程的运行情况、内存占用情况和cpu利用情况,但是更加奇怪的问题是无论是运行ps还是free都出现了sh: can't fork的错误信息,这是什么鬼东西,去Google搜索了各种资料(不要问我怎么上的Google,你懂的),没有得到任何有用的信息,所以只能靠感觉定位了,既然没办法fork,可能是内存被占用完了,那么目前就需要确认系统的内存使用情况。

       1、free命令用不了,ls也出现报错,通过各种方式最后在/proc路径下vi meminfo看到了内存信息,内容如下:

        MemTotal:       16357468 kB
        MemFree:         4878352 kB
        MemAvailable:    7485820 kB
        Buffers:          538576 kB
        Cached:          1894516 kB

       发现内存还有4个多G没使用完,那么就能排除内存不足导致的fork出现错误了。

      2、既然不是内存问题,那么还有什么原因导致了,我查了fork的相关接口代码,发现fork主要动作是创建子进程,创建子进程如果内存充足怎么会创建失败呢?后来搜到一个命令ulimit -a查看系统当前用户的资源限制信息,才知道可能是线程数超过了系统的最大限制数量,从而导致的fork失败的发生。为了验证这个猜想我查看了ulimit -a命令结果:

HH:~#ulimit -a
        -f: file size (blocks)  

  • 2
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值