it-swarm-pt.tech

É possível obter um dump principal de um processo em execução e sua tabela de símbolos?

É possível obter o gdb ou usar algumas outras ferramentas para criar um dump principal de um processo em execução e sua tabela de símbolos? Seria ótimo se houvesse uma maneira de fazer isso sem encerrar o processo.

Se isso for possível, quais comandos você usaria? (Estou tentando fazer isso em uma caixa Linux)

50
Readonly
 $ gdb --pid = 26426 
 (gdb) gcore 
 Salvo corefile core.26426 
 (gdb) desanexar 
60
DustinB

Ou execute gcore $(pidof processname).

Isso tem o benefício (de executar o gdb e emitir comandos para a CLI) que você anexa e desanexa no menor tempo possível. 

51
Alex Zeffertt

Você pode usar o comando generate-core-file no gdb para gerar o despejo principal do processo em execução.

0
Dev

Nota: O método a seguir terminará o processo em execução e também exigirá os símbolos.

Você pode enviar um dos seguintes sinais (com action = core) para o processo em execução:
De: http://man7.org/linux/man-pages/man7/signal.7.html

       Signal     Value     Action   Comment
       ──────────────────────────────────────────────────────────────────────
       SIGHUP        1       Term    Hangup detected on controlling terminal
                                     or death of controlling process
       SIGINT        2       Term    Interrupt from keyboard
       SIGQUIT       3       Core    Quit from keyboard
       SIGILL        4       Core    Illegal Instruction
       SIGABRT       6       Core    Abort signal from abort(3)
       SIGFPE        8       Core    Floating point exception
       SIGKILL       9       Term    Kill signal
       SIGSEGV      11       Core    Invalid memory reference
       SIGPIPE      13       Term    Broken pipe: write to pipe with no
                                     readers
       SIGALRM      14       Term    Timer signal from alarm(2)
       SIGTERM      15       Term    Termination signal
       SIGUSR1   30,10,16    Term    User-defined signal 1
       SIGUSR2   31,12,17    Term    User-defined signal 2
       SIGCHLD   20,17,18    Ign     Child stopped or terminated
       SIGCONT   19,18,25    Cont    Continue if stopped
       SIGSTOP   17,19,23    Stop    Stop process
       SIGTSTP   18,20,24    Stop    Stop typed at terminal
       SIGTTIN   21,21,26    Stop    Terminal input for background process
       SIGTTOU   22,22,27    Stop    Terminal output for background process

Igual a:
kill <signal> <pid>

E depois de ter o núcleo, você pode abrir no gdb junto com o arquivo de símbolo.

0
brokenfoot