这几天在调试lepd的时候,遇到了这样的问题,系统运行一会,会出现“Too many open files”。这种问题是进程打开的文件句柄数超过了linux的上线,通常是1024。这类问题通常很棘手,不能马上找到问题。需要一个调试的过程:
1,运行lepd
2,在shell里不停 运行sudo lsof -p pid
还好不是很复杂,而且幸运的是,发现了不断增长的句柄, /dev/tty/pts/1什么的, 网上查了一下,跟telnet和ssl相关,但lepd并没有用到这两种技术。所以我想会不会与标准输入输出的管道相关,回看了代码,确实有一些文件没有妥善的关闭。
修改,编译,运行,lsof again,这次发现句柄的数量没有上升,同时也没有进程退出的现象了。