5

我们有一个多进程应用程序,其中调试特定的子进程被证明是困难的。由于进程之间的消息传递超时,我们没有时间将 gdb 附加到目标子进程,所以我想知道是否可以通过 systemtap 探针停止进程?

我认为应该需要一个简单的探测,例如:

probe process("exeName").mark("STOP_HERE")
{
    force_sig(SIGSTOP, current);
}

不幸的是,上面没有编译......有什么想法吗?


我不是 systemtap 专家,所以这可能不是最好的解决方案,但对于任何有兴趣的人来说,这是我的粗略解决方案:

#!/bin/stap -g

global gdbRunning = 0;

probe process(@1).mark(@2)
{
    raise(%{ SIGSTOP %});

    gdbCmd = sprintf("cgdb -- -q -ex 'thread find %d' %s %d", tid(), @1, pid());

    if (gdbRunning == 0)
    {
        gdbRunning = 1;
        printf("STOP PID %d TID %d [%s]\n", pid(), tid(), gdbCmd);
        system(gdbCmd);
    }
    else
    {
        printf("STOP PID %d TID %d\n", pid(), tid());
    }
}
4

1 回答 1

5

参见 man function::raise(3stap),从 systemtap 2.3 (2013-07-25) 开始新。

stap -g -e 'probe WHATEVER { raise(%{ SIGSTOP %}) }'

您需要大师模式才能让您的脚本使用此功能。

于 2013-12-10T14:14:49.017 回答