У меня есть скрипт, выполняющий команды, такие как:
export LD_LIBRARY_PATH=.:$LD_LIBRARY_PATH;./some_app -i $INDEX | tee $LOG
echo "Number of errors: $(grep "ERROR" $LOG | wc -l)"
Проблема, вероятно, в трубе tee
. Похоже, не получить весь вывод. Когда приложение завершает работу, последние несколько строк вывода (обычно те, которые содержат фатальную ошибку) отсутствуют. Когда я запускаю приложение без канала, tee
я получаю их в выводе.
Как я могу заставить скрипт ждать, пока тройник завершит обработку всего вывода?
Ответы:
Вероятно, фатальная ошибка возникает в STDERR (2), а не в STDOUT (1). Вы можете перенаправить STDERR в STDOUT с помощью,
2>&1
а затем канал должен захватить его тоже.Если у вас есть проблемы с буферизацией, вы можете перевести ее в состояние без буферизации:
источник
Поскольку сообщения об ошибках обычно отображаются в STDERR (дескриптор файла 2), вам необходимо перенаправить STDOUT и STDERR в
tee
:Когда вы это делаете,
./some_app -i $INDEX | tee $LOG
вы только перенаправляете STDOUT наtee
.|&
приведет к перенаправлению как STDOUT, так и STDERR.Если вы не можете перенаправить только STDOUT (как вы были):
С другой стороны, если вы хотите перенаправить только STDERR:
источник