POSIXシグナルのソースを見つける方法


13

Red Hat Enterprise Linux 5(SIGTERMなど)で送信されたシグナルの発信元を確認する方法はありますか?私は定期的にアプリケーションでTERMをトラップしていますが、どこから来たのかわかりません。

回答:


14

のmanページsigaction(2)は、シグナル送信者のPIDがシグナルハンドラに渡されるsiginfo_t構造体で利用可能であることを示唆しています。これには明らかにsigaction()を使用する必要があります。

manページから:

sigaction構造は次のように定義されます:

   struct sigaction {
       void     (*sa_handler)(int);
       void     (*sa_sigaction)(int, siginfo_t *, void *);
       sigset_t   sa_mask;
       int        sa_flags;
       void     (*sa_restorer)(void);
   };

そして、siginfo_t構造は次のようになります。

   siginfo_t {
       int      si_signo;    /* Signal number */
       int      si_errno;    /* An errno value */
       int      si_code;     /* Signal code */
       int      si_trapno;   /* Trap number that caused
                                hardware-generated signal
                                (unused on most architectures) */
       pid_t    si_pid;      /* Sending process ID */
       uid_t    si_uid;      /* Real user ID of sending process */
       int      si_status;   /* Exit value or signal */
       clock_t  si_utime;    /* User time consumed */
       clock_t  si_stime;    /* System time consumed */
       sigval_t si_value;    /* Signal value */
       int      si_int;      /* POSIX.1b signal */
       void    *si_ptr;      /* POSIX.1b signal */
       int      si_overrun;  /* Timer overrun count; POSIX.1b timers */
       int      si_timerid;  /* Timer ID; POSIX.1b timers */
       void    *si_addr;     /* Memory location which caused fault */
       int      si_band;     /* Band event */
       int      si_fd;       /* File descriptor */
   }

答えをありがとう、それほど多くの詳細を期待していませんでした。私はJavaサービスラッパーを使用しています。「デバッグ」に設定すると、次のように出力されます。詳細:シグナル番号= 15(SIGTERM)、source = "kill、sigsendまたはraise"シグナルはPID:2194(セッションPID:2164)、UID:1002(alfresco)によって生成されます。ラッパーunix cソース。:
user27451 09

1

DTraceを備えたプラットフォーム(OS X、Solarisなど)では、次のようなプローブでそれを使用して、必要な情報を記録できます。

sudo dtrace -n 'proc:::signal-send { printf("Process %d (%s by UID %d) sending signal %d to pid=%d\n",pid,execname,uid,args[2],args[1]->pr_pid); }'

これは、http: //www.brendangregg.com/DTrace/dtrace_oneliners.txt の下部にあるスクリプトと、https://stackoverflow.com/a/10465606/179583にある「関連する変数名」のヒントに基づいています。いくつかの基本的なテストの下で動作するようです。今、私のプロセスだけが予期せず再び死ぬなら!;-)


1
他のプラットフォームのstrace場合、私が間違えなければ同じ目的を果たします。この記事に従うことで、プロセスが受信した信号を追跡することができました。
アーロン

-2

いいえ、誰が信号を送信しているかわかりません。


2
それは必ずしもそうではありません。
ラースク09
弊社のサイトを使用することにより、あなたは弊社のクッキーポリシーおよびプライバシーポリシーを読み、理解したものとみなされます。
Licensed under cc by-sa 3.0 with attribution required.