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 / 1472059
Accepted
Anthony Naddeo
Anthony Naddeo
Asked: 2019-08-17 08:20:28 +0800 CST2019-08-17 08:20:28 +0800 CST 2019-08-17 08:20:28 +0800 CST

Múltiplos tubos em um log de cauda - o último tubo nunca recebe stdin

  • 772

Eu entrei em um estado interessante no Ubuntu. As etapas abaixo descrevem melhor.

Com um único tubo, estou vendo o que espero

# In shell A
tail -f foo.log | grep aaa

# In shell B
echo aaa >> foo.log

# Shell A prints out `aaa`

Mas com vários tubos não estou vendo nada

# In shell A
tail -f foo.log | grep aaa | grep bbb

# In shell B
echo aaa bbb >> foo.log

# Nothing ever prints in shell A

Mas funciona bem se eu estiver apenas ecoando.

echo 'aaa bbb' | grep aaa | grep bbb

Esta é minha tentativa de criar uma reprodução mínima - originalmente encontrei o problema ao tentar tee logs do adb logcat (ferramentas de desenvolvimento do Android). Eu tentei em zsh, bash e fish também.

Presumi que tivesse algo a ver com o limite do inotify watcher, mas ultrapassá-lo não mudou nada.

linux ubuntu
  • 1 1 respostas
  • 262 Views

1 respostas

  • Voted
  1. Best Answer
    Kamil Maciorowski
    2019-08-17T11:15:08+08:002019-08-17T11:15:08+08:00

    Isso ocorre por causa do buffer no pipe, que em geral não se preocupa com linhas e pode acumular dados.

    Acho que tail -fusa o buffer de linha por si só; e o último grepgrava no tty, então também usa buffer de linha. Portanto, seu primeiro exemplo funciona.

    Mas grepno meio é diferente e você precisa ajustar seu comportamento forçando o buffer de linha ou desabilitando o buffer. Os comandos abaixo funcionarão conforme o esperado.

    • Se o seu grepsuporte --line-buffered(ele faz no Ubuntu):

        tail -f foo.log | grep --line-buffered aaa | grep bbb
      
    • Soluções mais genéricas (funcionarão com muitos filtros diferentes de grep):

        tail -f foo.log | unbuffer -p grep aaa | grep bbb
        tail -f foo.log | stdbuf -oL grep aaa | grep bbb
        tail -f foo.log | stdbuf -o0 grep aaa | grep bbb
      

    Veja man 1 grep, man 1 unbuffere man 1 stdbufpara detalhes e peculiaridades.

    Notas:

    • Nenhuma das soluções é portátil ( grep --line-buffered, unbuffere stdbufnão são especificadas pelo POSIX).
    • Se você pode fazer isso grep --line-buffered, então deve ser sua escolha. Não adianta usar ferramentas extras.
    • Pergunta relacionada no Unix e Linux SE: Desligue o buffer no pipe .
    • unbuffere stdbuf trabalham de maneiras completamente diferentes .
    • Com stdbuf, o buffer de linha ( -oL) deve ser preferido a nenhum buffer ( -o0) aqui, porque
      • provavelmente tem um desempenho melhor,
      • e outras partes do seu pipe usam o buffer de linha de qualquer maneira.
    • Se o seu último grepescreveu em outro arquivo, ele se comportaria como o outro arquivo grep. Nesse caso, se você deseja que as linhas apareçam no arquivo final imediatamente, também deve modificar o comportamento do último arquivo grep.
    • Em fish, if grepé uma função wrapper, você pode não obter o comportamento desejado com --line-buffered. Use command grep --line-buffered. Veja esta pergunta: O tubo de saída espera pelo EOF emfish .

    Nota lateral: tail foo.log | grep aaa | grep bbb(ou seja, tailsem -f) não causa o problema porque tailsai. Quando tailsai, o primeiro grepdetecta EOF, libera seu buffer e sai, então o segundo grepfaz o mesmo.

    • 3

relate perguntas

  • Existe um equivalente a cd - para cp ou mv?

  • pasta compartilhada vmwared não está funcionando

  • execute o contêiner do docker como root

  • Como ativar o sensor de impressão digital no domínio e no diretório ativo do Linux

  • Como alterar permanentemente Ctrl + C para Ctrl + K no CentOS 7?

Sidebar

Stats

  • Perguntas 205573
  • respostas 270741
  • best respostas 135370
  • utilizador 68524
  • Highest score
  • 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

    Serviço do Windows 10 chamado AarSvc_70f961. O que é e como posso desativá-lo?

    • 2 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
  • Marko Smith

    ssl.SSLCertVerificationError: falha na verificação do certificado [SSL: CERTIFICATE_VERIFY_FAILED]: não foi possível obter o certificado do emissor local (_ssl.c:1056)

    • 4 respostas
  • Marko Smith

    Como posso saber em qual unidade o Windows está instalado?

    • 6 respostas
  • Martin Hope
    Albin Como faço para ativar o WindowsXP agora que o suporte acabou? 2019-11-18 03:50:17 +0800 CST
  • Martin Hope
    fixer1234 O "HTTPS Everywhere" ainda é relevante? 2019-10-27 18:06:25 +0800 CST
  • Martin Hope
    Kagaratsch O Windows 10 exclui muitos arquivos minúsculos muito lentamente. Algo pode ser feito para agilizar? 2019-09-23 06:05:43 +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
    Inter Sys Como Ctrl+C e Ctrl+V funcionam? 2019-05-15 02:51:21 +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