可能有些系统资源不足.显而易见的事情 – cpu使用率 – 看起来没问题.
哪些linux实用程序可能最适合捕获和分析此类事物,并尽可能不引人注意,因为这是一个高负载系统?它似乎需要是流程而不是系统导向.也许正在持续监控/ proc / pID / XX? top在这里似乎没什么用处.
解决方法 如果你能够发现这个“无反应的时刻”,那么你可以使用strace在这段时间内附加到相关进程并尝试找出它“睡觉”的位置:strace -f -o LOG -p <pID>
更轻巧但不太可靠的方法:
>当进程挂起时,使用top / ps / gdp / strace / ltrace来查找进程的状态(例如,它是否在“select”中等待或在某些库调用中消耗100%cpu)
>了解相关调用的一般性质,定制strace的调用以记录特定的系统调用或系统调用.例如,要仅记录与文件访问相关的系统调用,请使用:
strace -e file -f -o LOG ....
如果strace对你来说太重了,请尝试监控:
>使用“vmstat 1> / some / log”的内存使用情况 – 在此期间可能正在交换(或退出)进程>使用vmstat / iotop进行IO使用 – 也许其他一些进程正在颠覆磁盘> / proc / interrupts – 也许您的T1卡的驱动程序遇到了问题?
总结以上是内存溢出为你收集整理的确定在Linux上停止进程的原因全部内容,希望文章能够帮你解决确定在Linux上停止进程的原因所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)