我有一个命令运行了很长时间,我不想打扰它。但是,我想继续检查该过程(大多数时候是远程的)。我不断通过诸如、top
等命令监视该进程。该进程是一个基于终端的进程,不是通过或或类似命令启动的。因此检查输出的唯一方法是使用物理访问。iotop
stat
screen
tmux
我知道其中/proc
包含很多有关该过程的信息。所以我想知道它是否也可以显示输出(甚至只是最后一批输出——字符/字/行)。我搜索过/proc/<pid>/fd
,但找不到任何有用的东西。
下面是输出ls -l /proc/26745/fd/*
lrwx------ 1 user user 64 Oct 28 13:19 /proc/26745/fd/0 -> /dev/pts/17
lrwx------ 1 user user 64 Oct 28 13:19 /proc/26745/fd/1 -> /dev/pts/17
lrwx------ 1 user user 64 Sep 27 22:27 /proc/26745/fd/2 -> /dev/pts/17
有什么指点吗?
答案1
我会用strace
它:
strace -qfp PID -e trace=write -e write=1,2
这将跟踪write(2)
PID 及其子进程的所有系统调用,并十六进制转储写入文件描述符 1 和 2 的数据。
当然,这不会让你看到这个过程有什么已经写入 tty,但将从某个点开始监视所有写入。
另外,strace
不适合更改其输出格式——如果您需要更大的灵活性,您应该探索使用gdb(1)
或编写一个小程序。ptrace(2)