Tenho uma situação reproduzível em que uma instância do compilador entra em estado zumbi quando reconstruo um pacote, mas gdb
não me permite anexar:
serenity ~ # ps ax | grep defunct
11351 pts/1 Z+ 0:00 [x86_64-pc-linux] <defunct>
21838 pts/5 S+ 0:00 grep --colour=auto defunct
serenity ~ # gdb -p 11351
GNU gdb (Gentoo 7.10.1 vanilla) 7.10.1
[snip]
Attaching to process 11351
warning: process 11351 is a zombie - the process has already terminated
ptrace: Operation not permitted.
(gdb)
Essa questãosugere que o problema é com proc.sys.kernel.yama.ptrace_scope
, ou que posso não ser root, mas que o sysctl não está presente no meu sistema, e eusourodando como root:
serenity ~ # sysctl -a | grep ptrace
sysctl: reading key "net.ipv6.conf.all.stable_secret"
sysctl: reading key "net.ipv6.conf.default.stable_secret"
sysctl: reading key "net.ipv6.conf.enp4s0.stable_secret"
sysctl: reading key "net.ipv6.conf.lo.stable_secret"
serenity ~ # whoami
root
serenity ~ #
Para referência, minha versão do kernel é 4.9.16-gentoo
.
Responder1
Conforme declarado na saída da sua pergunta, um processo zumbi é aquele que terminou a execução, então você nunca poderá anexá-lo usando gdb - tudo o que é agora é uma entrada na tabela de processos do kernel sem nenhum processo ou recursos correspondentes, então não há nada para o gdb anexar.
A única razão pela qual esta entrada na tabela de processos existe, marcada como zumbi, é para que seu status de saída seja lido.