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.
teecomando grava stdinno (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/nullque 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 cmdpara 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/nullredirecionamento, 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/nullvocê, 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 teerespostas 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 zshmanual 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
file1através de file8como 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
teecomando já foi mencionado.
zsh, você pode usarsome_command >output_log_1 >output_log_2.