プロセスがどのシグナルを聞いているかを確認する方法は?

プロセスがどのシグナルを聞いているかを確認する方法は?

実行中のプロセスがシグナルをキャプチャするか、無視するのか、ブロックするのかを確認する方法は?理想的には、信号のリストを見たい、または少なくとも確認するために実際に信号を送信する必要はありません。

ベストアンサー1

Linuxでは、プロセスのPIDを参照できます/proc/$PID/status。これには、どの信号がブロックされたか(SigBlk)、無視されたか(SigIgn)、またはキャプチャされたか(SigCgt)を説明する行が含まれています。

# cat /proc/1/status
...
SigBlk: 0000000000000000
SigIgn: fffffffe57f0d8fc
SigCgt: 00000000280b2603
...

右側の数字はビットマスクです。これを16進数から2進数に変換すると、各1ビットはキャプチャされた信号を表し、右から左へ1ずつ計算されます。したがって、SigCgtラインを解釈すると、私のinitプロセスが次の信号をキャプチャしていることがわかります。

00000000280b2603 ==> 101000000010110010011000000011
                     | |       | ||  |  ||       |`->  1 = SIGHUP
                     | |       | ||  |  ||       `-->  2 = SIGINT
                     | |       | ||  |  |`----------> 10 = SIGUSR1
                     | |       | ||  |  `-----------> 11 = SIGSEGV
                     | |       | ||  `--------------> 14 = SIGALRM
                     | |       | |`-----------------> 17 = SIGCHLD
                     | |       | `------------------> 18 = SIGCONT
                     | |       `--------------------> 20 = SIGTSTP
                     | `----------------------------> 28 = SIGWINCH
                     `------------------------------> 30 = SIGPWR

kill -l(bashで実行して数値と名前のマッピングを見つけました。)

編集する:一般のニーズに応じて、POSIX sh形式のスクリプトが作成されました。

sigparse () {
    i=0
    # bits="$(printf "16i 2o %X p" "0x$1" | dc)" # variant for busybox
    bits="$(printf "ibase=16; obase=2; %X\n" "0x$1" | bc)"
    while [ -n "$bits" ] ; do
        i="$(expr "$i" + 1)"
        case "$bits" in
            *1) printf " %s(%s)" "$(kill -l "$i")" "$i" ;;
        esac
        bits="${bits%?}"
    done
}

grep "^Sig...:" "/proc/$1/status" | while read a b ; do
        printf "%s%s\n" "$a" "$(sigparse "$b")"
    done # | fmt -t  # uncomment for pretty-printing

おすすめ記事