URL: https://www.opennet.me/cgi-bin/openforum/vsluhboard.cgi
Форум: vsluhforumID9
Нить номер: 2599
[ Назад ]

Исходное сообщение
"duplicate stdout to file descriptor - что я дулаю не так?"

Отправлено Станислав Линке , 25-Фев-04 15:14 
Есть некий поток рождаемый ./getdata, мне его надо пропарсить в ./parsedata. Что-то вроде этого:

./getdata | ./parsedata

При этом, сам поток мне надо сохранить где-нибудь, на случай если возникнет ошибка парсинга. При этом сделать это в parsedata я не могу.

(1) Есть ли стандартное решение вида:

./getdata | save_and_echo -f backupfile.txt | ./parsedata

чтобы в файл сохранила и дальше в stdout свой передала. И на SIGPIPE не реагировала (если ./parsedata отвалился).

(2) Можно ли средствами bourne shell это сделать?
Читаю в документации:
[n1]>&n2 duplicate stdout (or file descriptor n1) to file descriptor n2
Пытаюсь выполнить:

./getdata 3>backupfile.txt >&3 | ./parsedata

при этом до parsedata данные не доходят, а оседают в backupfile.txt. Может быть, я неправильно понимаю смысл duplicate stdout? Это не данные дублируются, а сам дескриптор?


Содержание

Сообщения в этом обсуждении
"duplicate stdout to file descriptor - что я дулаю не так?"
Отправлено HFSC , 25-Фев-04 15:29 
>Есть некий поток рождаемый ./getdata, мне его надо пропарсить в ./parsedata. Что-то
>вроде этого:
>
>./getdata | ./parsedata
>
>При этом, сам поток мне надо сохранить где-нибудь, на случай если возникнет
>ошибка парсинга. При этом сделать это в parsedata я не могу.
>
>
>(1) Есть ли стандартное решение вида:
>
>./getdata | save_and_echo -f backupfile.txt | ./parsedata
>
>чтобы в файл сохранила и дальше в stdout свой передала. И на
>SIGPIPE не реагировала (если ./parsedata отвалился).
>
>(2) Можно ли средствами bourne shell это сделать?
>Читаю в документации:
>[n1]>&n2 duplicate stdout (or file descriptor n1) to file descriptor n2
>Пытаюсь выполнить:
>
>./getdata 3>backupfile.txt >&3 | ./parsedata
>
>при этом до parsedata данные не доходят, а оседают в backupfile.txt. Может
>быть, я неправильно понимаю смысл duplicate stdout? Это не данные дублируются,
>а сам дескриптор?


man tee


"duplicate stdout to file descriptor - что я делаю не так?"
Отправлено Станислав Линке , 26-Фев-04 08:42 
Спасибо за tee!

Остаётся добавить, что tee выходит после SIGPIPE и данные пропадают.

Что с этим делать:

(1) Я скопировал исходник nohup, добавил туда строку (void)signal(SIGPIPE, SIG_IGN); (в то месте, где другие вызовы signal) и откомпилировал его в nohupipe.

./getdata | nohupipe tee -i data.dump | ./parsedata

(2) Стандартные решения? Какие - не знаю.


"duplicate stdout to file descriptor - что я делаю не так?"
Отправлено vt , 26-Фев-04 17:26 
>(2) Стандартные решения? Какие - не знаю.

./getdata > file &
tail -n +1 -f file | ./parsedata