假设Linux机器上的一个进程似乎卡住了,我如何判断它是否由于STDOUT或STDERR缓冲区已满而卡住?
在我的特殊情况下,我有一个没有执行CPU活动的进程,但当我期望它在几秒钟内退出时,它仍然在运行。我怀疑该进程已经填满了STDOUT或STDERR的缓冲区,而本应从该缓冲区读取数据的进程由于某种原因而停止了读取。
我有没有办法证实这种怀疑?
发布于 2013-01-21 11:57:26
附加gdb和运行回溯几乎证实了我的理论……
$ gdb /opt/our_process pid
...blah blah blah...
(gdb) bt
#0 0x0000003f27adae60 in __write_nocancel () from /lib64/libc.so.6
#1 0x0000003f27a71583 in _IO_new_file_write () from /lib64/libc.so.6
#2 0x0000003f27a7144a in _IO_new_file_xsputn () from /lib64/libc.so.6
#3 0x0000003f27a49531 in buffered_vfprintf () from /lib64/libc.so.6
#4 0x0000003f27a4449e in vfprintf () from /lib64/libc.so.6
#5 0x0000003f27a4f03a in printf () from /lib64/libc.so.6
...out process's stack...而像shelter suggested这样的策略似乎也能做到这一点。
$ strace -p 27689
Process 27689 attached - interrupt to quit
write(1, "some_text"..., 293https://stackoverflow.com/questions/14432169
复制相似问题