30.进程池IPC

进程池代码的问题:

常见子进程,关父进程关闭读3,用4写,再创建子进程,父进程用3读,用5写,第二个子进程还是用3读。但是第二个子进程可能继承4写,这样的话还有别的引用计数,不能彻底关掉,那么就阻塞,读端不会读到0.所以不能把stop和wait写到一个for循环

所以方法1:从下往上关,就行,方法2:就让一个指向一个文件描述符,让下一个把继承的哥哥进程的w端关了就行。调用closeall就能全部关掉看代码

,父进程每次创建完管道子进程都会把管道和子进程给cm容器,子进程创建时候会继承父进程数据,cm就是历史上打开的文件描述符的写端。第一次创建时候cm是空,close什么都没做,第二次创建时候,已经保存第一次创建的文件描述符所以关闭时候所以只有第一个进程文件描述符写端。父进程修改会发生写时拷贝 。

看代码。


命名管道:

为什么要有两个struct file;因为每个进程读写位置不一样,但是操作系统根据inode number发现同一个文件后 所以struct file指向同样inode 文件缓冲区,

磁盘会刷新到外面,所以有个管道文件,

创建命名管道,p开头文件类型

echo就是个进程,向管道写入,cat也是个进程,这就是进程间通信。这就是命名管道。

unlink fifo就删掉了

如何用代码实现命名管道。就是让一个进程创建一个命名管道,后面就是文件操作。

系统调用:

mode代表读还是写

lesson25看看代码

相关推荐
nuomigege2 小时前
beagleboneblack刷入官方IOT镜像后无法运行nodered问题的处理
linux·运维·服务器
huaxiu52 小时前
ubuntu下应用打不开
linux·运维·ubuntu
m0_683124792 小时前
Ubuntu服务设置开机自启
linux·运维·ubuntu
BestOrNothing_20152 小时前
(1)双系统中Ubuntu22.04启动盘制作与启动盘恢复全过程
linux·ubuntu·双系统·启动盘制作·启动盘恢复
AI成长日志2 小时前
【实用工具教程】Linux常用命令速查与实战场景:文件操作、进程管理与网络调试高频命令解析
linux·php
落叶花开又一年2 小时前
检验检测机构资质认定远程评审工作程序
linux·运维·服务器
wanhengidc2 小时前
《三国志异闻录》搬砖新游戏 云手机
运维·服务器·数据库·游戏·智能手机
idolao2 小时前
CentOS 7 安装 jdk-7u25-linux-x64.tar.gz 详细步骤(解压配置环境变量)
linux
i建模3 小时前
通过命令行使用密钥登录远程SSH主机
运维·ssh