# 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>
