วิธีค้นหาแหล่งสัญญาณของ POSIX


12

มีวิธีการหาที่มาของสัญญาณที่ส่งใน Red Hat Enterprise Linux 5 (SIGTERM ฯลฯ ) หรือไม่? ฉันติดกับ TERM เป็นประจำในแอปพลิเคชันและฉันไม่รู้ว่ามาจากไหน

คำตอบ:


13

หน้า man สำหรับ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 */
   }

ขอบคุณสำหรับคำตอบไม่ได้คาดหวังรายละเอียดมากมาย ฉันใช้โปรแกรมห่อหุ้มบริการของ Java และเมื่อตั้งค่าเป็น "ดีบั๊ก" มันจะพิมพ์บางอย่างเช่นนี้: สัญญาณติดอยู่ รายละเอียด: หมายเลขสัญญาณ = 15 (SIGTERM), source = "kill, sigsend or Ra" สัญญาณที่สร้างโดย PID: 2194 (Session PID: 2164), UID: 1002 (alfresco) ฉันพบเฉพาะหลังจาก googling สำหรับ "si_pid" และการค้นหา wrapper unix c source :-)
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
โดยการใช้ไซต์ของเรา หมายความว่าคุณได้อ่านและทำความเข้าใจนโยบายคุกกี้และนโยบายความเป็นส่วนตัวของเราแล้ว
Licensed under cc by-sa 3.0 with attribution required.