【后端开发】多进程命名管通通信【无血缘关系进程】PHP 版本

【后端开发】多进程命名管通通信【无血缘关系进程】PHP 版本

后端开发2019-10-20 21:5090ki4网
进程通信:

1、中断系统

2、无名管道【半双工通信】

只能用于父子进程,兄弟进程之间的通信,且没有名字,称为无名管道,传输的数据是无格式的,双方可自己定义格式,不依赖于文件系统。

推荐:《PHP教程》

3、命名管道

用于无名管道无法实现的骚操作 ,没任何关系的进程也能进行通信【就是依赖于一个文件描述符,只不过这文件是一个 FIFO 类型的文件即管道文件,遵守 FIFO 原则,即队列先进先出】

PS:务必了解进程阻塞,非阻塞原理,管道文件,进程【运行状态转移】

应用场景举例说明: 如使用 php 的 socket API 编写一个类似 workerman 的网络框架,可以做统一中断信号事件处理

中断处理程序只负责接受中断请求,通过管道写端写入数据,主进程通过监听文件描述符上的事件【可读事件【可以私下去撸一下 stream socket 相关 API,以及了解下 IO 复用函数的使用方法】再处理。不会让中断处理程序等待过长的时间。

当然通过命名管道也可以实现跨语言进程间的通信。

$filePath = $argv[1];
if (posix_mkfifo($filePath,0666)<0){
    fprintf(STDOUT,"命名管道创建错误");
    exit(0);
}
$fd = fopen($filePath,"w");
while (is_resource($fd)){
    fprintf(STDOUT,">");
    $data = fgets(STDIN);
    if ($data){
        fwrite($fd,$data,strlen($data));
    }
}
exit(0);
$filePath = $argv[1];
if (posix_mkfifo($filePath,0666)<0){
    fprintf(STDOUT,"命名管道创建错误");
    exit(0);
}
$fd = fopen($filePath,"r");
while (is_resource($fd)){
    $data = fgets($fd);
    if ($data){
        fwrite(STDIN,$data,strlen($data));
    }
}
exit(0);

以上就是多进程命名管通通信【无血缘关系进程】PHP 版本的详细内容,更多请关注ki4网其它相关文章!

炫龙网络 Copyright ©  本站由阿里云强力驱动
【后端开发】多进程命名管通通信【无血缘关系进程】PHP 版本