Piping StdOut добавляет больше текста

Я запускаю простую команду (некоторые вещи, связанные с Кафкой):

curl localhost:8083

Его вывод очень прост:

root@debian:/etc/kafka# curl localhost:8083/
{"version":"0.11.0.0-cp1","commit":"6a8cf706ddc9ab6a"}root@debian:/etc/kafka#

Но сейчас, когда я использую утилиту jq для форматирования json добавляется больше строк:

root@debian:/etc/kafka# curl localhost:8083/ | jq
  % Total    % Received % Xferd  Average Speed   Time    Time     Time  Current
                                 Dload  Upload   Total   Spent    Left  Speed
100    54  100    54    0     0   1492      0 --:--:-- --:--:-- --:--:--  1500
{
  "version": "0.11.0.0-cp1",
  "commit": "6a8cf706ddc9ab6a"
}

То же самое происходит, если я less или же cat ожидаемым образом curl ... | less, Так что это не имеет ничего общего с jq сам.

Мои знания обо всех stdin, stdout, stderr, каналах (которые являются просто соединениями stdout и sdtin), файловых перенаправлений > < 2>и т. д. не объясняет это поведение.:(

1 ответ

Решение

Как и многие инструменты UNIX, вывод curl зависит от того, к какому типу устройства подключен стандартный вывод. В этом случае прокачка нашего ресурса через jq меняет тип с TTY в pipe, что приводит к нежелательному дополнительному выводу.

curl имеет переключатель командной строки -sглушит этот дополнительный вывод, поэтому работает curl -s localhost:8083/ | jq должен решить вопрос.

Другие вопросы по тегам