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
clockdiff
detecta 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, GNUls
com--color=auto
). O comportamento declockdiff
é 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
clockdiff
noiputils 20221126
meu 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 testeiclockdiff
, é uma solução:script
– também testado, é uma solução (masscript
adicionará um cabeçalho e um rodapé ao arquivo; e até mesmo sua entrada (ecoada), portanto, obter informações de</dev/null
é uma boa ideia):socat
compty
opção – isso eu também testei, é uma solução:biblioteca compartilhada personalizada usada com
LD_PRELOAD
- também testada, é uma solução (e observe que se você quiser,sudo clockdiff …
provavelmenteLD_PRELOAD=… sudo clockdiff …
não funcionará, emborasudo 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_PRELOAD
truque é 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 inesperadamenteInappropriate ioctl for device
); masclockdiff
nos 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
).socat
e oLD_PRELOAD
truque permite que você diferencie facilmente stdout e stderrclockdiff
.