Linux 系统的兼容性问题
POSIX 定义:
POSIX 表示可移植操作系统接口:Portable Operating System Interface,电气和电子工程师协会(Institute of Electrical and Electronics Engineers,IEEE)最初开发 POSIX 标准,是为了提高 UNIX 环境下应用程序的可移植性。
GNU utility 定义:
GNU 是 GNU Is Not UNIX 的递归缩写。Linux 的开发使用了许多 GNU 工具。Linux 系统上用于实现 POSIX 标准的工具几乎都是 GNU 项目开发的,如 emacs 编辑器、著名的 GNU C 和 C++ 编译器。
兼容性问题 1:
GNU/Linux 与 POSIX 标准基本是兼容的,但是在一些情况下,GNU utility 的默认行为和 POSIX 标准有不兼容的地方。
兼容性问题 2:
Linux 系统的不同版本采用了不同版本的 POSIX 标准,而 POSIX 不同版本标准之间有不兼容的地方。
这两个不兼容问题对于产品在 Linux 各个平台之间的可移植性影响很大,因此,掌握如何解决这两个兼容性问题非常重要。
在一些情况下,GNU utility 的默认行为和 POSIX 标准不兼容。为了解决这种不兼容情况,Linux 系统引入了环境变量’POSIXLY_CORRECT’。
设置方法:
export POSIXLY_CORRECT=TRUE
取消设置:
unset POSIXLY_CORRECT
例如:df命令(报告文件系统的磁盘使用情况)输出在 POSIX 标准下和 GNU 下是不同的。要使系统 GNU utilities 完全遵从 POSIX 标准,可以设置环境变量’POSIXLY_CORRECT’。
POSIX 细节:
输出结果在缺省时以 512 字节为计数单位,若给以 -k 选项,则以 1024 字节为计数单位。
GNU 细节:
(在没有用选项指定计数单位的情况下)输出结果以 1024 字节为计数单位,但不包括由于设置了环境变量’POSIXLY_CORRECT’而跟从 POSIX 标准的情况。
清单 1. df 命令输出
# df
Filesystem 1K-blocks Used Available Use% Mounted on
/dev/sda1 70675484 9834248 57251112 15% /
# export POSIXLY_CORRECT=True
# df
Filesystem 512B-blocks Used Available Use% Mounted on
/dev/sda1 141350968 19668496 114502224 15% /
# df –k
Filesystem 1K-blocks Used Available Use% Mounted on
/dev/sda1 70675484 9834248 57251112 15% /
# unset POSIXLY_CORRECT
# df
Filesystem 1K-blocks Used Available Use% Mounted on
/dev/sda1 70675484 9834248 57251112 15% /
Linux系统的不同版本采用了不同版本的POSIX标准,如 RedHat3,4系统采用的是旧版本 POSIX 标准 1003.2-1992,RedHat5 采用的是新版本 POSIX 标准 1003.1-2001,新旧版本的 POSIX 标准在一些地方有不兼容情况存在。
GNU utilities 通常遵从的 POSIX 版本就是系统所在的 POSIX 版本。RedHat5 GNU utilities 采用的是新的 POSIX 版本,RedHat3,4 采用的是旧的 POSIX 版本,由于 POSIX 新旧版本之间有不兼容存在,导致一些在 RedHat3,4 上运行良好的应用程序和脚本直接移植到 RedHat5 上不能正常运行行。
比如,’tail +2 ’这个命令在旧版本 POSIX 上的意思是得到文件从第二行到末尾的内容,但是从新的 POSIX 版本 1003.1-2001 开始,这个命令的意思变成了得到文件’+2’的内容,如果你想得到真正文件的内容,就得改用命令’tail –n +2 ’。
清单 2. 文件 wln.txt 内容
# more wln.txt
It is sunny today,
you are an industrious boy,
give the room a good sweep
这是用于下面tail命令示例的文件。
清单 3. 在旧版本POSIX上运行
# tail +2 wln.txt
you are an industrious boy,
give the room a good sweep.
旧版本POSIX用’tail +2’可以正确显示文件前两行内容。
清单 4. 在新版本POSIX上运行
# tail +2 wln.txt
tail: cannot open `+2` for reading: No such file or directory
==> wln.txt <==
It is sunny today,
you are an industrious boy,
give the room a good sweep.
# tail –n +2 wln.txt
you are an industrious boy,
give the room a good sweep.
新版本POSIX用’tail +2’命令不能正确显示文件前两行内容,必须用’tail –n +2’命令才行。
为了解决不同版本的 POSIX 标准的兼容性问题,使得 GNU utilities 能和不同版本的 POSIX 标准工作,Linux 系统引入了环境变量’_POSIX2_VERSION’,这个变量的格式是 YYYYMM,表示 POSIX 标准采用的年代和月份。
当前’_POSIX2_VERSION’有两个值:
‘199209’ 代表 POSIX 1003.2-1992
‘200112’ 代表 POSIX 1003.1-2001
设置用法:
export _POSIX2_VERSION=199209
取消设置:
unset _POSIX2_VERSION
如果你有旧版本的应用程序和脚本想移植到采用新版本 POSIX 标准的系统上运行,比如’tail +10’,’sort +1’等,你就能通过设置环境变量’_POSIX2_VERSION=199209’来解决兼容性。
清单 5. 使用’_POSIX2_VERSION’环境变量
# tail +2 wln.txt
tail: cannot open `+2` for reading: No such file or directory
==> wln.txt <==
It is sunny today,
you are an industrious boy,
give the room a good sweep.
# export _POSIX2_VERSION=199209
# tail +2 wln.txt
you are an industrious boy,
give the room a good sweep.
引
本文讲述了Linux系统下的两个环境变量解决兼容性问题的方法。Linux是个开源的系统,通过这两个环境变量的使用,提高了应用程序在不同Linux版本之间的移植性。
入’_POSIX2_VERSION’变量后,’tail +2’能够正确显示文件前两行了。