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 / 1813893
Accepted
King David
King David
Asked: 2023-10-24 19:10:23 +0800 CST2023-10-24 19:10:23 +0800 CST 2023-10-24 19:10:23 +0800 CST

linux + por que a saída do comando não pode ser filtrada ou pode ser salva em arquivo

  • 772

clockdiffé um comando que mede a diferença de clock entre hosts

aqui está um exemplo da minha máquina Linux.

clockdiff -o 162.23.2.2
.
host=server11 rtt=750(187)ms/0ms delta=0ms/0ms Tue Oct 24 11:01:42 2023

o problema é quando queremos filtrar a saída ou salvar a saída em um arquivo como o seguinte

clockdiff -o 162.23.2.2 >/tmp/file

more /tmp/file

1698145574 0 0

como podemos ver acima, a saída do arquivo não é a saída quando executamos o comando no console

alguma idéia de como salvar a saída da seguinte forma:

.
host=server11 rtt=750(187)ms/0ms delta=0ms/0ms Tue Oct 24 11:01:42 2023
linux
  • 1 1 respostas
  • 51 Views

1 respostas

  • Voted
  1. Best Answer
    Kamil Maciorowski
    2023-10-25T15:19:40+08:002023-10-25T15:19:40+08:00

    clockdiffdetecta se seu stdout é um dispositivo terminal ou não, ele formata sua saída de maneira diferente em ambos os casos. Isto é semelhante ao comportamento de ferramentas que, por exemplo, colorem automaticamente sua saída para um terminal, mas omitem códigos de cores ao gravar em um pipe ou em um arquivo normal (por exemplo, GNU lscom --color=auto). O comportamento de clockdiffé semelhante em mecânica, mas bastante insano; como você descobriu, está muito além de "cosméticos", os resultados nos dois casos diferem muito.

    O (des) recurso não está (ou ainda não) documentado; ou pelo menos não o encontrei documentado. Se houver uma opção para desativar o (des) recurso, isso também não está documentado.

    Ignore todos os comentários e hipóteses que suspeitem de stderr ou algum problema com o arquivo para o qual você redirecionou. Eu testei clockdiffno iputils 20221126meu Debian 12, seu comportamento depende apenas de o stdout ser um terminal ou não.

    Para salvar o que você vê no terminal em um arquivo normal, você precisa enganar o clockdiff. Por favor, leia Como enganar um comando fazendo-o pensar que sua saída está indo para um terminal . O link leva a uma pergunta estabelecida em nosso site irmão; se quebrar, irá quebrar junto com todo o Stack Exchange (incluindo o superusuário), então não há necessidade de repetir tudo aqui. Abaixo há uma lista de possíveis ferramentas coletadas a partir de respostas selecionadas para a pergunta vinculada. Veja essas respostas para obter detalhes.

    Ferramentas possíveis:

    • ptybandage

    • unbuffer– isso eu testei clockdiff, é uma solução:

      unbuffer clockdiff -o 162.23.2.2 >/tmp/file
      
    • script– também testado, é uma solução (mas scriptadicionará um cabeçalho e um rodapé ao arquivo; e até mesmo sua entrada (ecoada), portanto, obter informações de </dev/nullé uma boa ideia):

      </dev/null script -qc 'clockdiff -o 162.23.2.2' -O /tmp/file
      
    • socatcom ptyopção – isso eu também testei, é uma solução:

      socat -u EXEC:'clockdiff -o 162.23.2.2',pty STDOUT >/tmp/file
      
    • biblioteca compartilhada personalizada usada comLD_PRELOAD - também testada, é uma solução (e observe que se você quiser, sudo clockdiff …provavelmente LD_PRELOAD=… sudo clockdiff …não funcionará, embora sudo LD_PRELOAD=… clockdiff …possa funcionar; mas tudo isso depende da política).

    Notas:

    • A maioria dessas ferramentas "engana um comando fazendo-o pensar que sua saída está indo para um terminal", conectando sua saída a um pseudoterminal criado exclusivamente para esse propósito. O comando não é enganado, ele recebe um terminal. O LD_PRELOADtruque é aquele que realmente engana. Faz o comando "pensar" que sua saída está indo para um terminal, sem fornecer um terminal. Um comando enganado pode se comportar mal quando tenta fazer algo no "terminal" que não é um terminal (por exemplo, o comando recebe inesperadamente Inappropriate ioctl for device); mas clockdiffnos meus testes se comportou bem.

    • Algumas dessas ferramentas conectam automaticamente o stderr do comando ao mesmo destino que o stdout, para que os dois fluxos sejam mesclados (no seu caso, ambos vão para /tmp/file). socate o LD_PRELOADtruque permite que você diferencie facilmente stdout e stderr clockdiff.

    • 1

relate perguntas

  • Como eu faria minha máquina Linux parecer que está executando o Windows?

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

  • 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

    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