Linux "Too many open files" 问题分析

在Linux系统上,遇到'Too many open files'错误通常意味着进程打开的文件数量超过了系统允许的最大值。本文深入分析了一次由于debuggerd进程未能正确关闭文件导致的压力测试异常情况,详细探讨了如何通过分析proc文件系统、跟踪文件描述符和系统调用来定位问题,并解释了fopen和open的区别。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

平台介绍:Linux3.10.40 + Android4.4.2

 

事情的起因是压力测试过程中生成的tombstone日志异常,日志形式如下:

=======================================================================

*** *** *** *** *** *** *** *** *** *** *** *** *** *** *** ***

Build fingerprint: 'xxxx'

Revision: '0'

pid: 16471, tid: 16471, name: UNKNOWN  >>> UNKNOWN <<<

signal 11 (SIGSEGV), code 1 (SEGV_MAPERR), fault addr 00000000

=======================================================================

第一个不正常的地方是"pid: 16471, tid: 16471, name: UNKNOWN  >>> UNKNOWN <<<"中进程和线程id是有的,但是后边的进程名字和程序路径显示的都是"UNKNOWN"。第二个不正常的地方是调用栈信息无效。

在Adroid中,tombstone日志文件是由debuggerd进程生成,这部分日志保存在/data/tombstones目录中。logcat日志中还包含一些额外信息,形式如下:

=======================================================================

Fatal signal 11 (SIGSEGV) at 0x00000000 (code=1), thread 16471 (进程名)

*** *** *** *** *** *** *** *** *** *

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值