管道是一种最基本的
一种简单的
进程间通信
(IPC)机制,作用于有血缘关系的进程之间,完成数据传递。调用pipe系统函数即可创建一个管道。有如下特质:
1. 其本质是一个伪文件(实为内核缓冲区)
2. 由两个文件描述符引用,一个表示读端,一个表示写端
3. 规定数据从管道的写端流入管道,从读端流出。
管道的原理: 管道实为内核使用环形队列机制,借助内核缓冲区(4k)实现。
管道的局限性:
A 数据自己读不能自己写;
B 数据一旦被读走,便不在管道中存在,不可反复读取;
C 由于管道采用半双工通信方式。因此,数据只能在一个方向上流动。
D 只能在有公共祖先的进程间使用管道。
1. 其本质是一个伪文件(实为内核缓冲区)
2. 由两个文件描述符引用,一个表示读端,一个表示写端
3. 规定数据从管道的写端流入管道,从读端流出。
管道的原理: 管道实为内核使用环形队列机制,借助内核缓冲区(4k)实现。
管道的局限性:
A 数据自己读不能自己写;
B 数据一旦被读走,便不在管道中存在,不可反复读取;
C 由于管道采用半双工通信方式。因此,数据只能在一个方向上流动。
D 只能在有公共祖先的进程间使用管道。
常见的通信方式有,单工通信、半双工通信、全双工通信。
匿名管道:
只能用于具有血缘关系的进程间通信,因此在这里我们可以调用fork函数,创建一个子进程,然后让父子进程通过管道进行通信;
同样可以在multiprocessing的Process中使用匿名管道来做父子进程之间的通信;
命名管道:
命名管道可在同一台计算机的不同进程之间或在跨越一个网络的不同计算机的不同进程之间,支持可靠的、单向或双向的数据通信。第二,它只能实现一个进程写另一个进程读,而如果需要两者同时进行时,就得重新打开一个管道。
为了使任意两个进程之间能够通信,就提出了命名管道(named pipe 或 FIFO)。
1、与管道的区别:提供了一个路径名与之关联,以FIFO文件的形式存储于文件系统中,能够实现任何两个进程之间通信。而匿名管道对于文件系统是不可见的,它仅限于在父子进程之间的通信。
2、FIFO是一个设备文件,在文件系统中以文件名的形式存在,因此即使进程与创建FIFO的进程不存在血缘关系也依然可以通信,前提是可以访问该路径。
3、FIFO(first input first output)总是遵循先进先出的原则,即第一个进来的数据会第一个被读走。
匿名管道