Як дізнатися джерело сигналу POSIX


12

Чи є спосіб дізнатися походження сигналу, що надсилається в Red Hat Enterprise Linux 5 (SIGTERM тощо)? Я регулярно вловлюю термін у додатку, і я не маю уявлення, звідки він надходить.

Відповіді:


13

Сторінка sigaction(2)підказки припускає, що PID відправника сигналу доступний у структурі siginfo_t, переданій вашому оброблювачу сигналів. Це очевидно вимагає використання 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), джерело = "вбити, відіслати або підняти" сигнал, згенерований PID: 2194 (сесія PID: 2164), UID: 1002 (alfresco), я дізнався лише після googling для "si_pid" та пошуку джерело оболонки unix c. :-)
user27451

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, а також додаткових підказок щодо "відповідних імен змінних" на веб-сторінці /programming//a/10465606/179583 , і, здається, працює під деяким базовим тестуванням. Тепер, якби мій процес несподівано знову загинув! ;-)


1
Для інших платформ є те, straceщо служить тій самій цілі, якщо я не помиляюся. Я зміг простежити сигнали, отримані процесом, дотримуючись цієї статті .
Аарон


-2

Ні, ти не знаєш, хто надсилає сигнал.


2
Це не обов'язково так.
larsks
Використовуючи наш веб-сайт, ви визнаєте, що прочитали та зрозуміли наші Політику щодо файлів cookie та Політику конфіденційності.
Licensed under cc by-sa 3.0 with attribution required.