2

我在 Sun Java 1.5 上运行 JBoss。有时,它会意外关闭(以有序的方式)。我怀疑其他一些进程正在向它发送 kill 或 CTRL+C 信号。

Unix/Solaris 上有没有办法追踪谁发送了信号?

4

2 回答 2

7

在 Solaris 上,您可以使用一个简单的 dtrace 脚本来查找谁正在杀死您的进程(假设它的名称是java,否则请调整它):

dtrace -qn '
proc:::signal-send
/ args[1]->pr_fname == "java" /
{
        printf("Process %d (%s by UID %d) sending signal %d to java (pid=%d)\n",
        pid,execname,uid,arg1,args[1]->pr_pid);
}'
于 2012-05-05T20:14:34.350 回答
1

您可以使用sigaction来确定信号的来源。pid 可能为零,因为信号是从内核发送的或通过某些用户交互(按 ctrl+c)

#include <signal.h>
#include <string.h>
#include <stdio.h>

static void signal_handler(int sig, siginfo_t *info, void *data) {

    printf ("signal: [%d], pid: [%d], uid: [%d]\n", sig,
            info->si_pid,
            info->si_uid );
}

int main(int argc, char *argv[]) {

    struct sigaction sa;
    memset ( &sa, '\0', sizeof ( struct sigaction ) );

    sa.sa_sigaction = &signal_handler;
    sa.sa_flags |= SA_SIGINFO;

    sigemptyset ( &sa.sa_mask );

    sigaction(SIGINT, &sa, NULL);
    sigaction(SIGTERM, &sa, NULL);
    sigaction(SIGQUIT, &sa, NULL);

    while ( 1 ) {
        sleep (1);
    }

    return 0;
}
于 2012-05-05T14:36:32.790 回答