《Unix网络编程》卷2 读书笔记 第3章- System V IPC,unixipc
《Unix网络编程》卷2 读书笔记 第3章- System V IPC,unixipc
1. 概述
- 三种类型的System V IPC:System V 消息队列、System V 信号量、System V 共享内存区
- System V IPC在访问它们的函数和内核为它们维护的信息上共享许多类似点。本章讲述所有这些共同属性。
- 下图汇总了所有System V IPC 函数
- 头文件sys/types.h把数据类型key_t定义为一个整数,通常是一个至少32位的整数
- 函数ftok把一个已经在的路径名和一个整数标识符转换成一个key_t值,称为IPC键
- 如果pathname不存在,或者对于调用进程不可访问,ftok返回-1
- 不能保证两个不同的路径名与同一个id的组合产生不同的键。
3. ipc_perm结构
- 内核给每个IPC对象维护一个信息结构,其内容跟内核给文件维护的信息类似
4. 创建与打开IPC通道
- 对于key值,应用程序有两种选择
- 所有三个XXXget函数都有一个名为oflag的参数,它指定IPC对象的读写权限位(ipc_perm结构的mode成员),并选择是创建一个新的IPC对象,还是访问一个已存在的IPC对象。
- System V IPC定义了自己的IPC_XXX常值,而并不像标准open函数以及Posix IPC函数那样使用O_CREAT和O_EXCL常值
- 注意:System V IPC函数将它们的IPC_XXX常值根权限位合到单个oflag参数中。而open函数有一个名为oflag和mode的参数
5. IPC 权限
- 每当使用某个XXXget函数创建一个新的IPC对象时,以下信息就保存到该对象的ipc_perm结构中
- 尽管一个进程可以通过调用XXXctl函数修改属主ID,但创建者ID却从不改变。XXXctl函数还允许一个进程修改某个IPC对象的mode成员
- 每当一个进程访问某个IPC对象时,IPC就执行两级检查,该对象被打开时(XXXget函数)执行一次,以后每次使用该对象时执行一次
- ipc_perm结构中含有一个seq的变量,它是一个槽位使用情况序列号。该变量是一个由内核为系统中每个潜在的IPC对象维护的计数器。每当删除一个IPC对象时,内核就递增相应的槽位号,若溢出则循环为0 。
- 该计数器的存在有两个原因:
7. ipcs、ipcrm程序
- 只能用于System V IPC,而不能用于Posix IPC
- ipcs -q -m -s
- ipcrm --all=msg
8. 内核限制
- sysctl命令
评论暂时关闭