获取正在运行的命令的最新输出

获取正在运行的命令的最新输出

我有一个命令运行了很长时间,我不想打扰它。但是,我想继续检查该过程(大多数时候是远程的)。我不断通过诸如、top等命令监视该进程。该进程是一个基于终端的进程,不是通过或或类似命令启动的。因此检查输出的唯一方法是使用物理访问。iotopstatscreentmux

我知道其中/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)

相关内容