Como redirecionar a saída padrão para vários arquivos de log? O seguinte não funciona:
some_command 1> output_log_1 output_log_2 2>&1
Como redirecionar a saída padrão para vários arquivos de log? O seguinte não funciona:
some_command 1> output_log_1 output_log_2 2>&1
Respostas:
Veja man tee
:
NOME: tee - leia da entrada padrão e grave na saída e nos arquivos padrão
SINOPSE: tee [OPÇÃO] ... [ARQUIVO] ...
Adequadamente:
echo test | tee file1 file2 file3
cmd 2>&1 | tee log1 log2
tentei executar como acima, mas preciso pressionar ctrl-c para redirecioná-lo para o segundo arquivo de log. também a saída é impressa no console. Desejo que a saída do comando seja redirecionada para os logs, mas não no console. qualquer ajuda é apreciada.
tee
comando grava stdin
no (s) arquivo (s) e também no stdout
. Se você não deseja que a saída apareça no terminal, é necessário redirecionar para o /dev/null
que normalmente faria.
echo test | tee --append file1 file2
Digamos que sua saída seja gerada a partir de uma função cmd()
:
cmd() {
echo hello world!
}
Para redirecionar a saída de cmd
para dois arquivos, mas não para o console, você pode usar:
cmd | tee file1 file2 >/dev/null
Isso funcionará para vários arquivos, considerando qualquer fonte de dados canalizada para tee:
echo "foobarbaz" | tee file1 file2 file3 file4 > /dev/null
Isso também funcionará:
echo $(cmd) | tee file1 file2 >/dev/null
Sem o /dev/null
redirecionamento, o tee enviará a saída para o stdout , além dos arquivos especificados.
Por exemplo, se isso for executado no console, você verá a saída lá. Executar a partir de um crontab, a saída aparecerá com a mensagem de status que é enviada para você (veja também a resposta de Gilles aqui https://unix.stackexchange.com/a/100833/3998 ).
Isso funcionou para mim no bash no Ubuntu 12.04 e foi verificado no Ubuntu 14.04 usando o GNU bash 4.3.11 (1); portanto, ele deve funcionar em qualquer versão recente do GNU bash.
version 4.3.11(1)-release (i686-pc-linux-gnu)
) no Ubuntu 14.04.
É um post antigo, mas eu o encontrei agora ...
Em vez de redirecionar a saída para > /dev/null
você, você pode redirecioná-la para o último arquivo:
echo "foobarbaz" | tee file1 > file2
Ou para anexar a saída:
echo "foobarbaz" | tee -a file1 >> file2
-a
no T)
Como o @jofel mencionado em um comentário na resposta, isso pode ser feito nativamente em zsh
:
echo foobar >file1 >file2 >file3
ou, com expansão de braçadeira:
echo foobar >file{1..3}
Internamente, isso funciona de maneira muito semelhante às tee
respostas fornecidas acima. O shell conecta o stdout do comando a um processo que canaliza para vários arquivos; portanto, não há qualquer vantagem técnica convincente para fazê-lo desta maneira (mas não uma boa aparência real). Veja o zsh
manual para mais informações.
Não é possível comentar, no entanto, outra maneira de expressar
echo "foobarbaz" | tee file1 file2 file3 file4 file5 file6 file7 file8 > /dev/null
Pode ser simplificado para isso, ao lidar com muitos arquivos.
echo "foobarbaz" | tee file{1..8} > /dev/null
file1
através de file8
como seus nomes e esses são provavelmente apenas a exemplo espaços reservados para os nomes dos arquivos
Eu precisava de um arquivo de log de sessão e outro arquivo para todas as sessões que fiz:
echo blabla |tee thisession >>allsessions
tee
comando já foi mencionado.
zsh
, você pode usarsome_command >output_log_1 >output_log_2
.