在将代码移植到 z/OS 平台时,您会面临的一个重要挑战是 POSIX semaphore API 在 z/OS 上的可用性。通常,在 Linux®/UNIX/Windows® 平台上运行的很多程序都是用 POSIX semaphore 开发的。
这个问题的一个解决方案是使用 System V API 代替 POSIX API 来实现 z/OS。这会涉及到整个代码中大量的代码更改,以及大量的编写和测试工作。另一个更好的解决方案是使用可用的 System V API 在 z/OS 中实现 POSIX API。如果采用这种方法,移植所需的代码更改会很少。这些代码更改不包含在应用程序代码中,而是作为单独的 semaphore 标头和 C 文件包含在内。此标头和 C 文件是通用的,可用于任何平台。
本文阐释了如何使用 System V Semaphore API 来实现 POSIX Semaphore API。
本文对于想要使用 POSIX API 但开发平台只支持 System V API(比如 z/OS)的">开发人员会非常有帮助。而且本文还会从开发角度对 POSIX 和 System V semaphore 进行显著的区分。
对比 POSIX Semaphore 和 System V Semaphore
Semaphore 可以有两种类型:POSIX Semaphore 或 System V semaphore。
您可以在 semaphores 上以单独的单元或以集合中的元素进行操作。由于 System V IPC semaphores 可以位于一个巨大的数组中,所以它们是属于极其重量级的。Semaphore 集合由一个控制结构和一个 semaphore 数组组成。一组 semaphore 可以包括最多 25 个元素。System V IPC semaphore 函数包括 semget()、semop() 和 semctl()。
semget() - 创建一个
新的 semaphore 集或使用 semget() 系统调用访问一个现有集合。 semop() - 执行 semaphore 操作。 semctl() - 如果您是该 semaphore 的创作者,
那么可以更改它的所有权或许可权限。
POSIX semaphore 要比 System V semaphore 轻很多。POSIX semaphore 结构定义了一个单一的 semaphore,而不是一个 semaphore 数组。POSIX semaphore 函数包括:
sem_open() - 连接到(也可以根据情况创建)一个命名的 semaphore sem_init() - 初始化一个 semaphore 结构(属于调用程序内部的结构,所以不是一个命名的 semaphore) sem_close() - 终止一个打开的 semaphore 的连接 sem_unlink() - 终止一个打开的 semaphore 的连接并在最后的进程关闭该连接时删除此 semaphore sem_destroy() - 初始化一个 semaphore 结构(属于调用程序内部的结构,所以不是一个命名的 semaphore) sem_getvalue() - 将 semaphore 的值复制到指定的整数 sem_wait() 和 sem_trywait() - 当 semaphore 由其他进程持有时会发生阻塞,或是如果 semaphore 由另一个进程持有,则返回一个错误 sem_post() - 增加 semaphore 的数目
POSIX 自带了创建、初始化和在 semaphore 上执行操作所对应的简单语义。这些语义提供了一种处理进程间通信的有效方式。如果您需要在单个步骤内执行多次增量-减量来实现原子操作,那么 System V semaphore 会非常有用。除此之外,请尽量使用 POSIX semaphore。
Semaphore 在 z/OS 上的限制
z/OS 只支持 System V Semaphore,不支持 POSIX semaphore。
在 z/OS 上没有可用的 POSIX API。z/OS 只有三个面向 semaphore 的 System V API,分别为 semop()、semget() 和 semctl()。如果想要在 z/OS 内使用 semaphore API,那么只能使用 System V API。
表 1. 不同平台上的 Semaphore 支持
Linux AIX® zLinux HP
Solaris Mac OS z/OS POSIX Y Y Y Y Y Y N System V Y Y Y Y Y Y Y
使用 System V Semaphore API 实现 POSIX Semaphore API
所有 POSIX semaphore 函数和类型都是在 semaphore.h 内原型化或定义的。在某些遗留平台(比如 z/OS)上,只有 System V semaphore 函数可用。因此,semaphore.h(用以定义 POSIX Semaphore 函数)在 z/OS 上是不可用的。System V semaphore 函数在 sys/sem.h 内原型化。