Linux的几种进程间通信方法简介

发布网友

我来回答

3个回答

懂视网

进程通信:

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);

热心网友

管道(pipe) 管道是Linux支持的最初IPC方式,管道可分为无名管道,有名管道等。 (一)无名管道,它具有几个特点: 1) 管道是半双工的,只能支持数据的单向流动;两进程间需要通信时需要建立起两个管道; 2) 无名管道使用pipe()函数创建,只能用于父子进程或者兄弟进程之间; 3) 管道对于通信的两端进程而言,实质上是一种的文件,只存在于内存中; 4) 数据的读写操作:一个进程向管道中写数据,所写的数据添加在管道缓冲区的尾部;另一个进程在管道中缓冲区的头部读数据。 (二)有名管道 有名管道也是半双工的,不过它允许没有亲缘关系的进程间进行通信。具体点说就是,有名管道提供了一个路径名与之进行关联,以FIFO(先进先出)的形式存在于文件系统中。这样即使是不相干的进程也可以通过FIFO相互通信,只要他们能访问已经提供的路径。 值得注意的是,只有在管道有读端时,往管道中写数据才有意义。否则,向管道写数据的进程会接收到内核发出来的SIGPIPE信号;应用程序可以自定义该信号处理函数,或者直接忽略该信号。 二。信号量(semophore) 信号量是一种计数器,可以控制进程间多个线程或者多个进程对资源的同步访问,它常实现为一种锁机制。实质上,信号量是一个被保护的变量,并且只能通过初始化和两个标准的原子操作(P/V)来访问。(P,V操作也常称为wait(s),signal(s)) 三。信号(Signal) 信号是Unix系统中使用的最古老的进程间通信的方法之一。操作系统通过信号来通知某一进程发生了某一种预定好的事件;接收到信号的进程可以选择不同的方式处理该信号,一是可以采用默认处理机制-进程中断或退出,一是忽略该信号,还有就是自定义该信号的处理函数,执行相应的动作。 内核为进程生产信号,来响应不同的事件,这些事件就是信号源。信号源可以是:异常,其他进程,终端的中断(Ctrl-C,Ctrl+\等),作业的控制(前台,后台进程的管理等),分配额问题(cpu超时或文件过大等),内核通知(例如I/O就绪等),报警(计时器)。 四。消息队列(Message Queue) 消息队列就是消息的一个链表,它允许一个或者多个进程向它写消息,一个或多个进程向它读消息。Linux维护了一个消息队列向量表:msgque,来表示系统中所有的消息队列。 消息队列克服了信号传递信息少,管道只能支持无格式字节流和缓冲区受限的缺点。 五。共享内存(shared memory) 共享内存映射为一段可以被其他进程访问的内存。该共享内存由一个进程所创建,然后其他进程可以挂载到该共享内存中。共享内存是最快的IPC机制,但由于linux本身不能实现对其同步控制,需要用户程序进行并发访问控制,因此它一般结合了其他通信机制实现了进程间的通信,例如信号量。 五。套接字(socket) socket也是一种进程间的通信机制,不过它与其他通信方式主要的区别是:它可以实现不同主机间的进程通信。

热心网友

第一种:管道通信
两个进程利用管道进行通信时,发送信息的进程称为写进程;接收信息的进程称为读进程。管道通信方式的中间介质就是文件,通常称这种文件为管道文件,它就像管道一样将一个写进程和一个读进程连接在一起,实现两个进程之间的通信。写进程通过写入端往管道文件中写入信息;读进程通过读出端从管道文件中读取信息。两个进程协调不断地进行写和读,便会构成双方通过管道传递信息的流水线。
第二种:消息缓冲通信
多个的进程之间可以通过消息缓冲机制来相互通信。这种通信的实现是以消息缓冲区为中间介质,通信双方的发送和接收操作均以消息为单位。在存储器中,消息缓冲区被组织成队列,通常称之为消息队列。消息队列一旦创建后即可由多进程共享,发送消息的进程可以在任意时刻发送任意个消息到指定的消息队列上,并检查是否有接收进程在等待它所发送的消息。若有则唤醒它,而接收消息的进程可以在需要消息的时候到指定的消息队列上获取消息,如果消息还没有到来,则转入睡眠等待状态。
第三种:共享内存通信
针对消息缓冲需要占用CPU进行消息复制的缺点,OS提供了一种进程间直接进行数据交换的通信方式。共享内存,顾名思义这种通信方式允许多个进程在外部通信协议或同步,互斥机制的支持下使用同一个内存段进行通信,它是一种最有效的数据通信方式,其特点是没有中间环节,直接将共享的内存页面通过附接映射到相互通信的进程各自的虚拟地址空间中,从而使多个进程可以直接访问同一个物理内存页面。

声明声明:本网页内容为用户发布,旨在传播知识,不代表本网认同其观点,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。E-MAIL:11247931@qq.com
2.126194s