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看看代码

相关推荐
Esaka_Forever29 分钟前
Zapier 云端无代码 AI 工作流编排自动化平台
运维·自动化
c2385643 分钟前
git常见错误和ssh验证推送
运维·git·ssh
火山上的企鹅1 小时前
Codex实战:APP远程升级服务搭建(四)Node 服务端自动识别 APK 信息
android·服务器·git·github·qgc
哈德森hh1 小时前
从手动操作到自动化管理:Twitter多账号运营效率优化实践
运维·自动化·twitter
IT WorryFree1 小时前
ESXi 全维度监控方式完整分类(按使用场景排序)
运维·服务器·网络
专注搞钱1 小时前
FAB设备OEE自动化分析工具:月度报表从2天缩短到30秒
运维·自动化
加加and减减1 小时前
Docker真实安装mysql8教程并优化配置
运维·mysql·docker·容器
herinspace1 小时前
管家婆辉煌软件如何新增往来单位档案分类
服务器·数据库·电脑·管家婆软件
RoboWizard2 小时前
一块硬盘上架前要闯多少关?
java·服务器·数据库
十六年开源服务商2 小时前
2026社交媒体营销×WordPress运维:实战避坑指南
运维·媒体