답변:
에 대한 매뉴얼 페이지 sigaction(2)
는 신호 송신기의 PID가 신호 핸들러에 전달 된 siginfo_t 구조에서 사용 가능함 을 제안합니다. 이를 위해서는 sigaction ()을 사용해야합니다.
매뉴얼 페이지에서 :
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 */
}
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 하단에있는 스크립트 와 /programming//a/10465606/179583의 추가 "관련 변수 이름"팁을 기반으로했습니다 . 몇 가지 기본 테스트에서 작동하는 것 같습니다. 이제 내 프로세스 만 예기치 않게 다시 죽으면! ;-)
systemtap을 사용하여 신호를 추적 할 수 있습니다. 다음은 간단한 예입니다
https://sourceware.org/systemtap/examples/lwtools/killsnoop-nd.stp