匿名管道
:利用内核中的一块缓冲区,可以通过系统调用的IO进行进程间的通信,但是由于这个缓冲区没有名字,所以只有在具有血缘关系的进程通过进程复制,才能公用一个缓冲区进行通信
特性:
1.(半双工通信)
2.读写特性:
- 管道是一块缓冲区,管道写满了,write()就会阻塞
- 管道中没有 数据read()就会阻塞。
- 若是所有的write()都关闭,这read()读取完所有数据之后,返回0(不会堵塞)
- 若管道的所有的读端关闭,则write()写入数据就会触发异常(SIGPIPE–进程退出)
命名管道的打开特性:
若管道当前没有被写的方式打开,以只读打开时,会阻塞
若管道当前人没有被已读的方式的打开时,只写的方式打开时,也会阻塞。
- 管道的生命周期随进程,进程结束,生命结束‘
- 管道自带同步与互斥(管道读写数据的大小不超过PIPE_BUFF时(4096字节),读写保证原子性)
同步:保证对临界资源访问的时序合理性
互斥:保证对临界资源访问的唯一性
- 管道提供字节流服务:
按字节为单位对数据进行读取
字节流读取的特性:
读取灵活,但是会造成数据粘连(粘包问题,传入的数据没有明显的界限,他们只会在缓冲区里堆积)
IPC控制(由于管道的生命周期随进程,而其他的通信随的是内核)
查看ipc ipcs -m(内存) s(信号量) q(队列)
删除ipcipcrm-m 0 删除共享内存 操作句柄为 0 的共享内存
memory_share_segment(共享内存) semaphore_arrays(信号量)
queue_message(消息队列)
命名管道:可以用于同一主机的所有进程间通信