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 / unix / Perguntas / 729344
Accepted
Ram Rachum
Ram Rachum
Asked: 2022-12-23 08:16:17 +0800 CST2022-12-23 08:16:17 +0800 CST 2022-12-23 08:16:17 +0800 CST

Por que não consigo fazer dois greps depois de uma cauda?

  • 772

Eu sou capaz de executar este comando com sucesso:

tail -f my_file.txt | grep foo

Ele mostra apenas as linhas com a string fooe continua mostrando-as.

Mas quando eu executo este comando:

tail -f my_file.txt | grep foo | grep bar

Ele não mostra nenhuma linha, embora existam linhas que incluam fooe bar.

Sei que existe uma solução para usar vários padrões em uma única grepchamada, mas quero saber por que essa linha falhou.

grep
  • 2 2 respostas
  • 1285 Views

2 respostas

  • Voted
  1. Best Answer
    ilkkachu
    2022-12-23T08:27:26+08:002022-12-23T08:27:26+08:00

    Isso ocorre porque o comportamento padrão da biblioteca de tempo de execução C é armazenar gravações em stdout até que um bloco completo de dados seja gravado (alguns kilobytes, geralmente), a menos que stdout esteja conectado a um terminal.

    Você obterá a saída assim que o grep do meio imprimir um bloco completo, mas precisará aguardar novamente o preenchimento do próximo bloco e assim por diante. É uma otimização para taxa de transferência e funciona muito melhor quando o comando esquerdo apenas executa alguma tarefa e termina, em vez de esperar por algo.

    GNU grep tem a --line-bufferedopção de desligar esse buffer, então isso deve funcionar melhor:

    tail -f my_file.txt | grep --line-buffered foo | grep bar
    

    O último grepé impresso no terminal, portanto, é armazenado em buffer de linha por padrão e não precisa de uma opção.

    Consulte Desativar o armazenamento em buffer no canal para obter soluções genéricas para o problema de armazenamento em buffer.


    Neste caso particular de dois greps, você poderia usar, por exemplo, um único AWK, como Stéphane Chazelas mencionou em um comentário:

    tail -f my_file.txt | awk '/foo/ && /bar/'
    

    (Aliás, você também pode fazer coisas como awk '/foo/ && !/bar/', pegar linhas com foomas não bar.)

    Fazer o mesmo em grep seria mais difícil, pois grep -e foo -e barcorresponde a qualquer linha que contenha ou foo . barVocê precisaria de algo como

    ... | grep -E -e 'foo.*bar|bar.*foo'
    

    em vez de.

    • 27
  2. Carlos Lint
    2022-12-24T23:22:20+08:002022-12-24T23:22:20+08:00

    De um ponto de vista booleano, parece que você está esperando foo OR bar com seu grep, mas do jeito que você fez, você deve esperar foo AND bar -- As únicas linhas que serão grepadas para bar são aquelas que passaram pelo foo grep em primeiro lugar.

    Se você quiser que foo/bar apareça no stdout, você precisa usar:

    tail -f meu_arquivo.txt | grep "foo|bar"

    Você pode adicionar quantas palavras-chave "bonito|muito|como|estes", só não se esqueça das aspas. (Ou use vários\|sem aspas\|termos )

    Em uma segunda observação: como é um tail -f (follow), também pode acontecer de your_file.txt não ser anexado com uma linha contendo as duas palavras-chave naquele momento muito específico, geralmente é melhor cortar uma parte desse arquivo que é conhecido por ter o que você espera:

    tail -n 500 meu_arquivo.txt > minha_amostra.txt

    A partir daí, você pode tentar qualquer grep que desejar com um texto conhecido. (Acho que as últimas 500 linhas são suficientes, ajuste conforme necessário.)

    • -2

relate perguntas

  • resultados inesperados de `service | grep`

  • Leia o arquivo de texto com palavras e sua contagem de ocorrências e saída de impressão classificada

  • Comando ls | grep mostrando apenas diretórios (quando também deveria mostrar arquivos)

  • quando o grep conta e quando não

  • grep --line-buffered até X linhas?

Sidebar

Stats

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

    Possível firmware ausente /lib/firmware/i915/* para o módulo i915

    • 3 respostas
  • Marko Smith

    Falha ao buscar o repositório de backports jessie

    • 4 respostas
  • Marko Smith

    Como exportar uma chave privada GPG e uma chave pública para um arquivo

    • 4 respostas
  • Marko Smith

    Como podemos executar um comando armazenado em uma variável?

    • 5 respostas
  • Marko Smith

    Como configurar o systemd-resolved e o systemd-networkd para usar o servidor DNS local para resolver domínios locais e o servidor DNS remoto para domínios remotos?

    • 3 respostas
  • Marko Smith

    apt-get update error no Kali Linux após a atualização do dist [duplicado]

    • 2 respostas
  • Marko Smith

    Como ver as últimas linhas x do log de serviço systemctl

    • 5 respostas
  • Marko Smith

    Nano - pule para o final do arquivo

    • 8 respostas
  • Marko Smith

    erro grub: você precisa carregar o kernel primeiro

    • 4 respostas
  • Marko Smith

    Como baixar o pacote não instalá-lo com o comando apt-get?

    • 7 respostas
  • Martin Hope
    user12345 Falha ao buscar o repositório de backports jessie 2019-03-27 04:39:28 +0800 CST
  • Martin Hope
    Carl Por que a maioria dos exemplos do systemd contém WantedBy=multi-user.target? 2019-03-15 11:49:25 +0800 CST
  • Martin Hope
    rocky Como exportar uma chave privada GPG e uma chave pública para um arquivo 2018-11-16 05:36:15 +0800 CST
  • Martin Hope
    Evan Carroll status systemctl mostra: "Estado: degradado" 2018-06-03 18:48:17 +0800 CST
  • Martin Hope
    Tim Como podemos executar um comando armazenado em uma variável? 2018-05-21 04:46:29 +0800 CST
  • Martin Hope
    Ankur S Por que /dev/null é um arquivo? Por que sua função não é implementada como um programa simples? 2018-04-17 07:28:04 +0800 CST
  • Martin Hope
    user3191334 Como ver as últimas linhas x do log de serviço systemctl 2018-02-07 00:14:16 +0800 CST
  • Martin Hope
    Marko Pacak Nano - pule para o final do arquivo 2018-02-01 01:53:03 +0800 CST
  • Martin Hope
    Kidburla Por que verdadeiro e falso são tão grandes? 2018-01-26 12:14:47 +0800 CST
  • Martin Hope
    Christos Baziotis Substitua a string em um arquivo de texto enorme (70 GB), uma linha 2017-12-30 06:58:33 +0800 CST

Hot tag

linux bash debian shell-script text-processing ubuntu centos shell awk ssh

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