ipc - System V 进程间通信机制
SYNOPSIS 总览
# include <sys/types.h>
# include <sys/ipc.h>
# include <sys/msg.h>
# include <sys/sem.h>
# include <sys/shm.h>
DESCRIPTION
本手册页涉及 System V 进程间通信机制在 Linux 下的实现: 消息队列, 信号灯集合, 以及共享内存段. 下面提到 资源 时, 就是指上面这些通信机制中的一种.
资源访问权限
对每个资源, 系统用一个共有的 struct ipc_perm 结构来存放权限信息, 以确定一个 ipc 操作是否可访问该资源. 在 <sys/ipc.h> 中定义了 ipc_perm, 其成员如下:
ushort cuid; /* 创建者 uid */
ushort cgid; /* 创建者 gid
*/
ushort uid; /* 所有者 uid
*/
ushort gid; /* 所有者 gid
*/
ushort mode; /* 读/写权限 */
结构 ipc_perm 的成员 mode 的低九位定义了对该资源的访问许可, 以确定一个执行了 ipc
系统调用的进程能否访问该资源. 其解释如下:
0400 用户可读.
0200 用户可写. 0040 组成员可读.
0020 组成员可写. 0004 其他用户可读.
0002 其他用户可写.
系统没有使用执行位 0100, 0010 和 0001. 另外, 这里的 "可写" 等效于信号灯集合里的 "可更改".
在 <sys/ipc.h> 系统头文件里还定义了如下符号常数:
- IPC_CREAT
- 如果 key 不存在就创建.
- IPC_EXCL
- 如果 key 已经存在则失败.
- IPC_NOWAIT
- 如果请求必须等待, 产生错误.
- IPC_PRIVATE
- 私有 key.
- IPC_RMID
- 删除资源.
- IPC_SET
- 设置资源选项.
- IPC_STAT
- 取得资源选项.
请注意 IPC_PRIVATE 是一个 key_t 类型, 而别的符号常数都是标志域,它们的可以或( OR )在一起形成 int 类型.
消息队列
消息队列由正整数 (它的 msqid) 唯一标识, 其结构体 struct msquid_ds 在 <sys/msg.h> 中定义, 包含如下成员:
struct ipc_perm msg_perm;
ushort msg_qnum; /* 队列中消息数目
*/
ushort msg_qbytes; /* 一条队列最大字节数
*/
ushort msg_lspid; /* 上一次 msgsnd
调用的 pid */
ushort msg_lrpid; /*
上一次 msgrcv 调用的 pid */
time_t
msg_stime; /* 上一次 msgsnd 的时间
*/
time_t msg_rtime; /* 上一次 msgrcv
的时间 */
time_t msg_ctime; /*
上一次修改时间 */
- msg_perm
- ipc_perm 结构, 指明了对该消息队列的访问权限.
- msg_qnum
- 该队列当前的消息总数.
- msg_qbytes
- 该队列所允许的消息正文最大字节总数.
- msg_lspid
- 最后做 msgsnd 系统调用的进程的 ID.
- msg_lrpid
- 最后做 msgrcv 系统调用的进程的 ID.
- msg_stime
- 最近做 msgsnd 系统调用的时间.
- msg_rtime
- 最近做 msgrcv 系统调用的时间.
- msg_ctime
- 最后一次改变 msqid_ds 结构成员的时间.
信号灯集合
信号灯集合由正整数 (它的 semid) 唯一标识, 并有一个与之关联的结构体 struct
semid_ds 它在 <sys/sem.h> 中定义, 包含如下成员:
struct ipc_perm sem_perm;
time_t sem_otime; /* 上一次操作的时间
*/
time_t sem_ctime; /* 上一次修改的时间
*/
ushort sem_nsems; /* 集合中信号灯数目
*/
- sem_perm
- ipc_perm 结构, 指明对该信号灯集合的访问权限.
- sem_otime
- 最近做 semop 系统调用的时间.
- sem_ctime
- 最近做 semctl 系统调用的时间, 该调用修改了上面结构的一个成员或者改变了属于该集合的一个信号灯.
- sem_nsems
- 该信号灯集合的信号灯数目. 集合中每个信号灯都可以用从 0 到 sem_nsems-1 的一个非负整数来引用.
一个信号灯就是一个 struct sem 结构, 包含如下成员:
ushort semval; /* 信号灯值
*/
short sempid; /* 上一次操作的进程的 pid
*/
ushort semncnt; /* 等待增加 semval 值的进程数目
*/
ushort semzcnt; /* 等待 semval = 0
的进程数目 */
- semval
- 该信号灯值,是一个非负整数.
- sempid
- 最后一个对该信号灯做操作的进程 ID.
- semncnt
- 等待增加 semval 的进程数.
- semznt
- 等待 semval 变成 0 的进程数.
共享内存段
共享内存段由正整数 (它的 shmid) 唯一标识, 有一个关联的结构类型 struct
shmid_ds 在 <sys/shm.h> 中定义, 包含如下成员:
struct ipc_perm shm_perm;
int
shm_segsz; /* 段尺寸 */
ushort
shm_cpid; /* 创建者 pid */
ushort
shm_lpid; /* 上一次操作的进程的 pid
*/
short shm_nattch; /* 目前附着的进程数目
*/
time_t shm_atime; /* 上一次附着的时间
*/
time_t shm_dtime; /* 上一次脱离的时间
*/
time_t shm_ctime; /* 上一次修改的时间
*/
- shm_perm
- ipc_perm 结构, 指明对共享内存段的访问权限.
- shm_segsz
- 共享内存段的大小, 以字节为单位.
- shm_cpid
- 创建该共享内存段的进程的 ID.
- shm_lpid
- 最后执行 shmat 或者 shmdt 系统调用的进程 ID.
- shm_nattch
- 当前对该共享内存段的活跃连接数.
- shm_atime
- 最后做 shmat 系统调用的时间.
- shm_dtime
- 最后做 shmdt 系统调用的时间.
- shm_ctime
- 最后做 shmctl 系统调用的时间, 如果该调用改变了 shmid_ds.
ipc - System V 进程间通信机制的更多相关文章
- 【linux高级程序设计】(第十一章)System V进程间通信 1
System V, 曾经也被称为 AT&T System V,是Unix操作系统众多版本中的一支. 传统上,System V 被看作是两种UNIX"风味"之一(另一个是 B ...
- Linux IPC System V 信号量
模型 #include <sys/types.h> #include <sys/ipc.h> #include <sys/sem.h> ftok() //获取key ...
- Linux IPC System V 消息队列
模型 #include <sys/types.h> #include <sys/ipc.h> #include <sys/msg.h> ftok() //获取key ...
- Linux IPC System V 共享内存
模型 #include<sys/types.h> #include<sys/ipc.h> #include<sys/shm.h> ftok() //获取key值 s ...
- system v进程间通信整理
key_t键和ftok函数 三种类型的system v IPC使用key_t值作为他们的名字.头文件<sys/types.h> 把key_t这个数据类型定义为一个整数,它通常是一个至少32 ...
- 【linux高级程序设计】(第十一章)System V进程间通信 3
信号量通信机制 可以看到,跟消息队列类似,也是包括两个结构. int semget (key_t __key, int __nsems, int __semflg) : 创建信号量集合 第一个参数:f ...
- System V进程间通信
一)Linux环境进程间通信(一)管道及有名管道http://www.ibm.com/developerworks/cn/linux/l-ipc/part1/二)Linux环境进程间通信(二): 信号 ...
- 【linux高级程序设计】(第十一章)System V进程间通信 4
共享内存 共享内存主要用于实现进程间大量数据传输. 共享内存的数据结构定义: 系统对共享内存的限制: 共享内存与管道的对比: 可以看到,共享内存的优势: 1.共享内存只需复制2次,而管道需要4次 2. ...
- 【linux高级程序设计】(第十一章)System V进程间通信 2
消息队列 消息队列是消息的链式队列,模型如下: 包括两种数据结构: msqid_ds消息队列数据结构 msg消息队列数据结构 struct msg_msg{ struct list_head m_li ...
随机推荐
- Python中Counter统计数据输出具体办法
from collections import Counter # 列表 l_one = [1709020621, 1709020621, 1770603107, 1770603105, 177060 ...
- CAN波特率设置
通过对CAN位定时寄存器CANBIT以及CAN波特率预分频扩展寄存器CANBRPE的设置可以得到需要的CAN通信波特率. CAN的位定时配置不当,将使得CAN模块无法按照目标波特率接入CAN网络,将导 ...
- IDEA超实用快捷键
1.查看某个方法在哪里被调用了 Ctrl+G 2.从Controller跳过接口快速进入到实现类的方法: Ctrl+T 3.快速打开:Generate Alt+Insert 4.生成包裹代码: Ctr ...
- anaconda 安装pyspider出错
注释Lib\mimetypes.py里面的 try: mimetype = mimetype.encode(default_encoding) except UnicodeEncodeErr ...
- <img>的title和alt有什么区别
1.title是全局属性之一,用于为元素提供附加的advisory information.通常当鼠标滑动到元素上的时候显示. 2.alt是<img>的特有属性,是图片内容的等价描述,用于 ...
- java里poi操作excel的工具类(兼容各版本)
转: java里poi操作excel的工具类(兼容各版本) 下面是文件内具体内容,文件下载: import java.io.FileNotFoundException; import java.io. ...
- Linux服务器重启后IP变掉的处理方式
工作中有一台服务器为物理机,重启后IP就变掉了,影响到了使用,于是将服务器上的IP配置为静态方式,问题得以解决,具体如下: 1.登陆Linux服务器,cd /etc/sysconfig/network ...
- java:Review(Oracle-HTML-CSS)
20170708_review: 1.oracle: 对表的操作: 使用命令行建立一张表:create table 表名 (列名 列名的类型 primarty key, ....); alter ta ...
- centos中切换图形与命令行界面
1.在命令行的centos中安装图形化 配置本地源 [root@localhost yum.repos.d]# yum clean all [root@localhost yum.repos.d]# ...
- Stream流实现斐波那契数列
1.前言 我们都知道斐波那契数列有很多种实现方法,在jdk1.8以前没有流操作,只能通过递归或者迭代等其他方式来实现斐波那契数列, 但是jdk1.8以后,有了流操作,我们就可以使用流来实现斐波那契数列 ...