Linux IPC技术概括

简介:
+关注继续查看


进程间通信IPC技术在其发展过程经历了一些变化,另外其包含众多技术概念,如果不从系统上去梳理一番容易迷失在这信号森林。

IPC是进程间通信的简称,不同的信息共享有多种方式如下图:

5ab8cd214cf0d4987eb2cf564a52a905724826b0

进程组对于进程间的通信机构——信号来说,是非常有用的。

其发展规律如下:

Unix IPC包括:

l   最初的管道、FIFO、信号;

l   System V IPC包括:System V消息队列、System V信号量、System V共享内存区;

l   Posix IPC包括:Posix消息队列、Posix信号量、Posix共享内存区。

现有大部分Unix和流行版本都是遵循POSIX标准的,而Linux从一开始就遵 循POSIX标准;

System V(System Five)是Unix操作系统众多版本中的一支,当年UNIX厂家混战中,比较强大的一个,最初由 AT&T 开发并在1983年第一次发布。一共发行了4个 System V 的主要版本:1、2、3 和 4,比如:System V Release 4,或者称为SVR4,是最成功的版本。

在POSIX IPC中, IPC对象使用ipc的名称作为ipc的标识。mq_open sem_open shm_open三个函数的第一个参数就是这个名称。在创建或者打开ipc对象时需要指定操作的mode,例如O_RONLY、O_WRONLY、O_RDWR、O_CREAT、O_EXCL 等,IPC对象是有一定权限的,与文件的权限类似。

在System V IPC中,System v ipc中有一个重要的类型是key_t,在msget、semget、shmget函数操作中都需要利用这个类型是参数。 

我们可以将进程间的通信主要分为如下4种:消息传递、同步、共享内存和远程过程调用。

            再理解下fork,exec,__exit对IPC对象的影响。

20469e46dbd9ca787e3153f4aa123a05ff0d7ecb

目录
相关文章
|
4天前
|
设计模式 安全 Java
《Linux从练气到飞升》No.31 多线程编程实践与线程安全技术
《Linux从练气到飞升》No.31 多线程编程实践与线程安全技术
16 0
|
8天前
|
存储 机器学习/深度学习 安全
Linux加强篇007-使用RAID与LVM磁盘阵列技术
山重水复疑无路,柳暗花明又一村
199 0
|
25天前
|
存储 Linux Docker
跨cpu架构部署容器技术点:怎样修改Linux 的内核版本
在使用Docker 进行跨平台部署之后,我们还可以尝试进行跨架构部署。 从X86 架构上移植到 aarch64 上。
41 0
|
1月前
|
存储 Linux 调度
2023年Linux的知识技术合集(基础入门到高级进阶)
2023年Linux的知识技术合集(基础入门到高级进阶)
|
1月前
|
Linux 测试技术 API
Linux内核调试技术(一)kprobe使用与实现
Linux内核调试技术(一)kprobe使用与实现
|
2月前
|
人工智能 弹性计算 并行计算
操作系统迁移难?Alibaba Cloud Linux 支持跨版本升级 | 龙蜥技术
无需担心数据丢失,无需考虑如何解决在升级后同步问题。
|
2月前
|
Linux
Linux 神奇命令大合集:掌控操作系统,成为技术达人!
Linux 神奇命令大合集:掌控操作系统,成为技术达人!
59 1
|
3月前
|
缓存 NoSQL 安全
Linux设备驱动程序(四)——调试技术3
Linux设备驱动程序(四)——调试技术3
46 0
|
3月前
|
安全 Unix Linux
Linux设备驱动程序(四)——调试技术2
Linux设备驱动程序(四)——调试技术2
23 0
|
3月前
|
NoSQL 安全 Linux
Linux设备驱动程序(四)——调试技术1
Linux设备驱动程序(四)——调试技术1
48 0
相关产品
云迁移中心
推荐文章
更多