我在 Sun Java 1.5 上运行 JBoss。有时,它会意外关闭(以有序的方式)。我怀疑其他一些进程正在向它发送 kill 或 CTRL+C 信号。
Unix/Solaris 上有没有办法追踪谁发送了信号?
在 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);
}'
您可以使用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;
}