AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • Início
  • system&network
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • Início
  • system&network
    • Recentes
    • Highest score
    • tags
  • Ubuntu
    • Recentes
    • Highest score
    • tags
  • Unix
    • Recentes
    • tags
  • DBA
    • Recentes
    • tags
  • Computer
    • Recentes
    • tags
  • Coding
    • Recentes
    • tags
Início / computer / Perguntas / 1803364
Accepted
Jim Worrall
Jim Worrall
Asked: 2023-08-10 08:09:56 +0800 CST2023-08-10 08:09:56 +0800 CST 2023-08-10 08:09:56 +0800 CST

zsh: stdout e stderr ambos para console E log

  • 772

Estou convertendo um script de bash para zsh e estou me debatendo há dias com a saída. Eu quero que o stdout e o stderr vão para o console e para um arquivo de log. Eu tentei de tudo que posso encontrar online, mas sem alegria. Eu li a seção de redirecionamento do manual do zsh, mas não encontrei nada que ajudasse, embora deva admitir que não está claro para mim.

Aqui estão as coisas que tentei perto do início do script, experimentalmente, e seus resultados:

exec 2>&1 | tee -i test.log     # everything in console, log created but empty
exec 2>&1 | tee -i > test.log   # everything in console, log created but empty
exec 1>>$LOG; exec 2>&1         # everything in log, none in console
exec 2>&1; exec 1>>$LOG         # console gets errors only; log stdout only
exec &> >(tee "$LOG")           # works in bash, error in zsh
exec > >(tee -i ${LOG?}) 2>&1   # error
exec |& tee $LOG                # error
exec > >(tee $LOG) 2>&1         # error

Eu também tentei entender os multios da opção zsh, mas não consegui entender muito. Deveria estar ativado por padrão, mas não o encontro na lista de opções quando executo setopt. Nem quando corro setopt multios. Quando corro unsetopt multios, vejo a opção nomultios, mas isso não parece ajudar

Entendo que perguntas semelhantes foram feitas e respondidas, mas as respostas estão principalmente na lista acima e não funcionaram para mim.

Não acho que seja relevante, mas também configurei um log de depuração que obtém o descritor de arquivo 3. É apenas para linhas de saída de depuração que terminam com >&3.

Observação para quem procura essa solução: os testes executivos acima foram feitos com um shebang confuso e os resultados com isso corrigido foram um pouco diferentes. Além da solução de Gairfowl, abaixo, também funcionou:

exec > >(tee $LOG) 2>&1
zsh
  • 1 1 respostas
  • 54 Views

1 respostas

  • Voted
  1. Best Answer
    Gairfowl
    2023-08-10T18:49:26+08:002023-08-10T18:49:26+08:00

    Isso parece funcionar:

    #!/usr/bin/env zsh
    exec >&1 >>log.txt 2>&1
    print -u1 stdout stuff
    print -u2 stderr info
    

    Teste:

    > ./testexec
    stdout stuff
    stderr info
    > cat log.txt
    stdout stuff
    stderr info
    

    Altere >>log.txtpara >log.txtse quiser sobrescrever o arquivo todas as vezes, em vez de anexá-lo. Isso também funcionou >>$logquando a logvariável foi definida como um nome de arquivo. A multiossintaxe é descrita nesta resposta e há um pouco mais de informação aqui .

    Isso requer que multiosesteja ativado - como você observou, esse é o padrão. set -o(nb: set, not setopt) pode ser usado para exibir o status de todas as opções; setoptsem parâmetros lista apenas as opções que foram alteradas do padrão.

    Algumas notas sobre as peças:

    • exec ...- o execbuiltin substituirá o shell atual por um novo processo. Quando é chamado assim sem um argumento de comando, a substituição é outra instância de zsh, com os redirecionamentos definidos para os novos valores na linha de comando. O efeito é quase idêntico a invocar um comando com esses redirecionamentos na linha de comando, por exemplo
      {print abc;print -u2 def} >&1 >log.txt 2>&1, .
    • >&1- redirecionar stdoutpara stdout. Sim, é um pouco redundante - este é um sinal para multioso que queremos continuar a enviar stdoutpara o seu destino atual (que provavelmente é o terminal), além dos seguintes redirecionamentos.
    • >>log.txt- adicione um redirecionamento para stdouto arquivo log.txtno modo de acréscimo. Este é um multioscomportamento específico; agora a saída padrão está sendo enviada para dois lugares, por meio de um mecanismo zshque se parece muito com tee.
    • 2>&1- enviar stderrpara o mesmo lugar que stdout. Graças aos dois redirecionamentos anteriores, stdoutestá indo para dois lugares, então isso também envia stderra saída para o arquivo e (provavelmente) para o terminal.
    • print -u<n>- apenas para teste. A -uopção envia a saída para o descritor de arquivo <n>.
    • 2

relate perguntas

  • Qual é a diferença entre $path e $PATH do zsh?

  • Alacritty + tmux não pode copiar grande parte do texto no modo de cópia

  • Comportamento estranho para a conclusão automática do zsh

  • substituindo zsh por bash no usuário não root

  • nenhum arquivo ou diretório: /Users/username/.oh-my-zsh/oh-my-zsh.sh

Sidebar

Stats

  • Perguntas 205573
  • respostas 270741
  • best respostas 135370
  • utilizador 68524
  • Highest score
  • respostas
  • Marko Smith

    Como posso reduzir o consumo do processo `vmmem`?

    • 11 respostas
  • Marko Smith

    Baixar vídeo do Microsoft Stream

    • 4 respostas
  • Marko Smith

    O Google Chrome DevTools falhou ao analisar o SourceMap: chrome-extension

    • 6 respostas
  • Marko Smith

    O visualizador de fotos do Windows não pode ser executado porque não há memória suficiente?

    • 5 respostas
  • Marko Smith

    Como faço para ativar o WindowsXP agora que o suporte acabou?

    • 6 respostas
  • Marko Smith

    Área de trabalho remota congelando intermitentemente

    • 7 respostas
  • Marko Smith

    O que significa ter uma máscara de sub-rede /32?

    • 6 respostas
  • Marko Smith

    Ponteiro do mouse movendo-se nas teclas de seta pressionadas no Windows?

    • 1 respostas
  • Marko Smith

    O VirtualBox falha ao iniciar com VERR_NEM_VM_CREATE_FAILED

    • 8 respostas
  • Marko Smith

    Os aplicativos não aparecem nas configurações de privacidade da câmera e do microfone no MacBook

    • 5 respostas
  • Martin Hope
    Vickel O Firefox não permite mais colar no WhatsApp web? 2023-08-18 05:04:35 +0800 CST
  • Martin Hope
    Saaru Lindestøkke Por que os arquivos tar.xz são 15x menores ao usar a biblioteca tar do Python em comparação com o tar do macOS? 2021-03-14 09:37:48 +0800 CST
  • Martin Hope
    CiaranWelsh Como posso reduzir o consumo do processo `vmmem`? 2020-06-10 02:06:58 +0800 CST
  • Martin Hope
    Jim Pesquisa do Windows 10 não está carregando, mostrando janela em branco 2020-02-06 03:28:26 +0800 CST
  • Martin Hope
    andre_ss6 Área de trabalho remota congelando intermitentemente 2019-09-11 12:56:40 +0800 CST
  • Martin Hope
    Riley Carney Por que colocar um ponto após o URL remove as informações de login? 2019-08-06 10:59:24 +0800 CST
  • Martin Hope
    zdimension Ponteiro do mouse movendo-se nas teclas de seta pressionadas no Windows? 2019-08-04 06:39:57 +0800 CST
  • Martin Hope
    jonsca Todos os meus complementos do Firefox foram desativados repentinamente, como posso reativá-los? 2019-05-04 17:58:52 +0800 CST
  • Martin Hope
    MCK É possível criar um código QR usando texto? 2019-04-02 06:32:14 +0800 CST
  • Martin Hope
    SoniEx2 Altere o nome da ramificação padrão do git init 2019-04-01 06:16:56 +0800 CST

Hot tag

windows-10 linux windows microsoft-excel networking ubuntu worksheet-function bash command-line hard-drive

Explore

  • Início
  • Perguntas
    • Recentes
    • Highest score
  • tag
  • help

Footer

AskOverflow.Dev

About Us

  • About Us
  • Contact Us

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve