Pipes is an inter-process communication method. Pipes are the oldest inter-process communication method in Unix. The below image depicts a basic mode of operation of a pipe. As can be seen from the image that pipe communication is uni-directional and data can only travel in a single direction in a pipe.
data:image/s3,"s3://crabby-images/b0272/b027238af14b79bbfa837e73e7656db0a03e1cfc" alt=""
As seen in the image, since a pipe is a byte stream, it does not follow any message boundaries. The processes that are using the pipe should handle the packet message boundaries themselves.
A pipe has a fixed buffer size and once the buffer is full, further writes to the PIPE will block or fail. A pipe can be created by using the “pipe system call”. It is provided below:
data:image/s3,"s3://crabby-images/f1f9e/f1f9e986b9e9a17343aa89023c9dc0dfb4cba50c" alt=""
The above API denotes an array parameter which can hold two file descriptors. If the call to pipe API is successful, in the array filedes[0] will be the read end of the pipe and filedes[1] will be the write end of the pipe.
A pipe can be used in inter-process communication between a parent process and a child process. In this example, the parent writes to the pipe and the child reads from the pipe. It is denoted pictorially below:
data:image/s3,"s3://crabby-images/96e7e/96e7ef4aca87f1233073db9e9b015f454328f562" alt=""
Refer the programming examples provide in Linux Programming interface for Pipes. A simple program for pipes presented below
data:image/s3,"s3://crabby-images/97fb1/97fb1e8d010cd46902091b99b5f3eee3d105bc98" alt=""
Pingback: Netlink Protocol Families | Hitch Hiker's Guide to Learning