Redirecionar stdout / stderr de um job em background do console para um arquivo de log?

7

Acabei de executar um job (assuma foo.sh).

./foo.sh
[Press Ctrl-Z to stop]
bg  # enter background

E gera saída para stdout e stderr. Existe algum método para redirecionar para stdout e stderr para outro arquivo em vez da tela atual?

    
por Daniel YC Lin 23.03.2014 / 16:05

1 resposta

12

Aparentemente eu interpretei mal sua pergunta na primeira vez, então aqui está minha resposta atualizada:

Depois de enviar seu programa para o segundo plano, primeiro você precisa encontrar o PID

pgrep foo.sh

Em seguida, você pode usar gdb para anexar a esse processo

gdb -p <PID>

Em gdb , você muda onde o programa grava para

p dup2(open("/path/to/file",577, 420), 1)
p dup2(1, 2)

você desanexa do processo e sai gdb

detach
quit

Uma pequena explicação

  • 577 é equivalente a O_CREAT|O_WRONLY|O_TRUNC
  • 420 é equivalente a S_IRUSR|S_IWUSR|S_IRGRP|S_IROTH
  • Portanto, a chamada para open abre o arquivo e o trunca para 0 bytes, se existir ou cria um novo com as permissões de arquivo corretas, se não existir
  • A primeira chamada para dup2 duplica o descritor de arquivo retornado pela chamada para open para o descritor de arquivo 1 (que é stdout )
  • A segunda chamada para dup2 duplica o descritor de arquivo 1 to 2 (que é stderr )
por 23.03.2014 / 16:10

Tags