V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
爱意满满的作品展示区。
rapiz
V2EX  ›  分享创造

catp - 打印已在运行的进程的输出

  •  1
     
  •   rapiz ·
    rapiz1 · 2022-07-23 21:05:07 +08:00 · 1733 次点击
    这是一个创建于 854 天前的主题,其中的信息可能已经有所发展或是发生改变。

    Use Case:

    有时候我们可能会 ./app > /dev/null 因为觉得不会需要它的输出。想要它的输出时,又不想重新运行。

    又或者某个后台进程根本不知道输出被重定向到哪里了。

    catp $pid 可以开始显示进程在这之后的输出。

    https://github.com/rapiz1/catp/

    10 条回复    2022-07-27 09:15:00 +08:00
    Monad
        1
    Monad  
       2022-07-23 21:14:25 +08:00 via iPhone
    确实有类似需求 前排关注一下
    AngryPanda
        2
    AngryPanda  
       2022-07-24 08:52:31 +08:00
    strace -p <pid> -e <fd> 也可以。例如:

    strace -p 1412 -p 1
    AngryPanda
        3
    AngryPanda  
       2022-07-24 08:52:48 +08:00   ❤️ 2
    strace -p 1412 -e 1
    610915518
        4
    610915518  
       2022-07-24 20:33:16 +08:00
    有时候会有类似需求,先 mark 了
    nmap
        5
    nmap  
       2022-07-25 18:25:40 +08:00
    @AngryPanda #3 -e 1 的意义是啥? man 上没看到😥
    AngryPanda
        6
    AngryPanda  
       2022-07-25 19:50:45 +08:00 via iPhone
    原理是什么? dup ?
    @n
    @nmap fd 啊。1 stdout 2 stderr
    nmap
        7
    nmap  
       2022-07-25 21:32:21 +08:00
    @AngryPanda #6 我之前也以为是这个,但做了实验,输出到文件,fd 不是 1 ,一样能抓到😢
    wwqgtxx
        8
    wwqgtxx  
       2022-07-26 07:31:47 +08:00
    @nmap 哪怕发生了输出重定向,fd 也仍然是 1 呀
    nmap
        9
    nmap  
       2022-07-26 09:36:30 +08:00
    @wwqgtxx #8 我都说了,文件的 fd 不是 1 ,一样能抓到
    AngryPanda
        10
    AngryPanda  
       2022-07-27 09:15:00 +08:00 via iPhone
    @nmap 帖代码吧
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   1221 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 24ms · UTC 18:26 · PVG 02:26 · LAX 10:26 · JFK 13:26
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.