回答:
Linuxカーネル4.7(コミット)以降、umaskはで使用できます/proc/<pid>/status
。
$ grep '^Umask:' "/proc/$$/status"
Umask: 0022
注:この回答はLinuxカーネル4.6以前に適用されます。カーネルの新しいバージョンについては、@ egmontの回答を参照してください。
umaskはprocfsで公開されていません。あったの試み多くの成功なしでそれを追加するには。
前にここでgdb
説明したように、を使用してumaskを取得する方法があります。
$ gdb --pid=4321
(gdb) call/o umask(0)
$1 = 077
(gdb) call umask($1)
$3 = 0
gdbはプロセスとそのスレッドを停止するため、umaskの一時的な変更は無視できることに注意してください。
それがあなたのケースに適している場合は、このワンライナーを使用できます:
$ gdb --batch -ex 'call/o umask(0)' -ex 'call umask($1)' --pid=4321 2> /dev/null | awk '$1 == "$1" {print $3}'
077
もう1つの方法は、実行中のプロセスを制御できる場合は、umaskをファイル、出力などに書き込んでそこから取得することです。
Linuxでは、systemtap
(としてroot
)、
stap -e 'probe kernel.function("do_task_stat") {
printf("%o\n", $task->fs->umask);
exit()
}
probe begin {system("cat /proc/4321/stat>/dev/null")}'
こうすることcat /proc/4321/stat
で、プローブトリガーするdo_task_stat
私たちがアクセスできる場所fs->umask
に対応するプロセスの分野をtask_struct
核にします。