Linux进程通信的方式

一、Linux进程通信的目的

  • 数据传输:一个进程需要将它的数据发送给另一个进程,比如业务进程将日志发给日志系统进行收集分析;

  • 共享数据:多个进程想要操作共享数据

  • 通知事件:一个进程需要向另外的进程发送消息,通知它们发生了某种事件,比如进程终止时要通知父进程;

  • 资源共享:多个进程之间共享同样的资源,为了做到这一点,需要内核提供锁和同步机制;

  • 进程控制:有些进程希望控制另一个进程,比如DEBUG进程,此时控制进程希望拦截另一个进程的所有缺陷和异常,并能够及时知道它的状态改变。

二、Linux进程通信的方式

2.1 管道(pipe、s_pipe、name_pipe)

普通管道pipe可用于切亲缘关系进程间通信,数据只能单向流动;

流管道s_pipe基于pipe增加了数据可以双向流动;

命名管道name_pipe在s_pipe基础上可用于非亲缘关系进程间的通信。

2.2 信号(singal)

信号是一种比较复杂的通信方式,用于通知接收进程某个事件已经发生,主要作为进程间以及同一进程不同线程之间的同步手段。

2.3 信号量(semophore)

信号量是一个计数器,可以用来控制多个进程对共享资源的访问,它常做为一个锁机制,防止某进程正在访问共享资源时,其他进程也访问该资源。

2.4 消息队列

消息队列是消息的链接表,存放在内核中并由消息队列标志符标识,消息队列克服了信号传递信息少、管道只能承载无格式字节流以及缓冲区大小受限等缺点。

2.5 共享内存

共享内存就是映射一段能被其他进程所访问的内存,这段共享内存由一个进程创建,但多个进程都可以访问。共享内存是最快的IPC(进程间通信)方式,它是针对其他进程间通信方式运行效率低而专门设计的。它往往与其他通信机制,如信号量配合使用,来实现进程间的同步和通信。

2.6 套接字

用的比较多,可用于不同机器的进程间通信。

参考:

Linux进程通信的几种方式:https://blog.csdn.net/gatieme/article/details/50908749

Last updated