Differences between revisions 2 and 8 (spanning 6 versions)
Revision 2 as of 2007-09-09 08:33:33
Size: 448
Editor: ppp073-116
Comment: uh ? what is this faq about
Revision 8 as of 2008-11-22 14:09:52
Size: 1173
Editor: localhost
Comment: converted to 1.6 markup
Deletions are marked like this. Additions are marked like this.
Line 1: Line 1:
[[Anchor(faq85)]]
== How do I prevent a named pipe from closing? ==
<<Anchor(faq85)>>
== How to write several times to a fifo without having to reopen it? ==
Line 4: Line 4:
We've found two ways so far:

 * Using a loop
  {{{
  while cat myfifo; do :; done}}}

 * Using tail
  {{{
  tail -n +1 -f myfifo}}}

What problem are you trying to solve?
Open a program that reads the pipe and send the output of several commands to it?
like:
The basic use of NamedPipes is:
Line 20: Line 8:
echo 'a' > myfifo
}}}

This works, but `cat` dies after reading one line. (In fact, what happens is each time the named pipe is closed by the ''writer'', this signals an end of file condition for the ''reader''. So `cat`, the reader, terminates because it saw the end of its input.)

What if we want to write several times to the pipe without having to restart the reader? We have to arrange for all our data to be sent without opening and closing the pipe multiple times.

If the commands are consecutive, they can be grouped:
{{{
cat < myfifo &
{ echo 'a'; echo 'b'; echo 'c'; } > myfifo
}}}

But if they can't be grouped for some reason, a better way is to assign a file descriptor to the pipe and write there:
{{{
cat < myfifo &

# assigning fd 3 to the pipe
Line 21: Line 27:
echo blah >&3
echo more blah >&3

# writing to fd 3 instead of reopening the pipe
echo 'a' >&3
echo 'b' >&3
echo 'c' >&3

# closing the fd
Line 24: Line 35:
}}} }}}

Closing the fd causes the pipe's reader to receive the end of file indication.

How to write several times to a fifo without having to reopen it?

The basic use of NamedPipes is:

mkfifo myfifo
cat < myfifo &
echo 'a' > myfifo

This works, but cat dies after reading one line. (In fact, what happens is each time the named pipe is closed by the writer, this signals an end of file condition for the reader. So cat, the reader, terminates because it saw the end of its input.)

What if we want to write several times to the pipe without having to restart the reader? We have to arrange for all our data to be sent without opening and closing the pipe multiple times.

If the commands are consecutive, they can be grouped:

cat < myfifo &
{ echo 'a'; echo 'b'; echo 'c'; } > myfifo

But if they can't be grouped for some reason, a better way is to assign a file descriptor to the pipe and write there:

cat < myfifo &

# assigning fd 3 to the pipe
exec 3>myfifo

# writing to fd 3 instead of reopening the pipe
echo 'a' >&3
echo 'b' >&3
echo 'c' >&3

# closing the fd
exec 3>&-

Closing the fd causes the pipe's reader to receive the end of file indication.

BashFAQ/085 (last edited 2016-10-17 20:45:47 by 163-172-21-117)