it-swarm.it

È possibile ottenere un core dump di un processo in esecuzione e la sua tabella dei simboli?

È possibile ottenere gdb o utilizzare altri strumenti per creare un core dump di un processo in esecuzione e la sua tabella dei simboli? Sarebbe bello se ci fosse un modo per farlo senza terminare il processo. 

Se questo è possibile, quali comandi useresti? (Sto provando a farlo su una macchina Linux)

50
Readonly
 $ gdb --pid = 26426 
 (gdb) gcore 
 Nucleo di core core salvato core.26426 
 (gdb) detach 
60
DustinB

Oppure esegui gcore $(pidof processname).

Questo ha il vantaggio (oltre a eseguire gdb e inviare comandi alla CLI) che si allegano e si scollegano nel più breve tempo possibile. 

51
Alex Zeffertt

È possibile utilizzare il comando generate-core-file in gdb per generare il core dump del processo in esecuzione.

0
Dev

Nota: Il seguente metodo terminerà il processo in esecuzione e richiede anche i simboli.

È possibile inviare uno dei seguenti segnali (con action = core) al processo in esecuzione:
Da: 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

Così:
kill <signal> <pid>

E una volta che hai il nucleo, puoi aprire in gdb insieme al file dei simboli.

0
brokenfoot