gentconf命令解释及用法

系统运维 waitig 440℃ 百度已收录 0评论

用途

将系统配置变量值写入标准输出。

语法

getconf [ -v specification ]
SystemwideConfiguration | PathConfiguration PathName ]
DeviceVariableDeviceName ]

getconf -a

描述

 SystemwideConfiguration 参数调用 getconf 命令,将 SystemwideConfiguration 参数所指定的变量值写到标准输出。

用 PathConfiguration 和 PathName 参数调用 getconf 命令,写入 PathConfiguration 参数为 PathName 参数指定路径指定的变量值,到标准输出。

getconf 命令,用 -a 标志调用,并写入全部系统配置变量值到标准输出。

getconf 命令,用 DeviceVariable 和 DeviceName 参数调用,写磁盘设备名或位置的值到标准输出,设备路径由 DeviceName 参数指定。

如果在系统中定义指定的变量且其值描述为可从 confstr 子例程得到,则指定变量的值按下列格式写入:

“%s\n”,< 值 >

否则,如果在系统中定义指定变量,其值按下列格式写入:

“%d\n”, < 值 >

如果指定变量是有效的但在系统中未定义,则将下列内容写入标准输出:

“undefined\n”

如果变量名无效或出现错误,就会有一个诊断消息写入标准错误。

标记

-a 规格显示了指定规格及版本,其配置变量等待确定。如果该标志未被指定,返回值将响应一个实现缺省值 XBS5 的相应的编辑环境。
-v将全部系统配置变量值写入标准输出。

参数

PathName为 PathConfiguration 参数指定路径名。
SystemwideConfiguration指定一个系统配置变量
PathConfiguration指定一个系统路径配置变量
DeviceName指定一个设备路径名。
DeviceVariable指定一个设备变量。

当列入下列的表格中的第一列符号被用作 system_var 操作数时,getconf 将产生与用第二列的值调用 confstr 时相同的值:

注:

_CS_AIX_ARCHITECTURE 和 _CS_AIX_BOOTDEV 变量,用做 confstr 参数时,只对 root 用户可用。

system_varconfstr 名称值
BOOT_DEVICE_CS_AIX_BOOTDEV
MACHINE_ARCHITECHTURE_CS_AIX_ARCHITECTURE
MODEL_CODE_CS_AIX_MODEL_CODE
PATH_CS_PATH
XBS5_ILP32_OFF32_CFLAGS_CS_XBS5_ILP32_OFF32_CFLAGS
XBS5_ILP32_OFF32_LDFLAGS_CS_XBS5_ILP32_OFF32_LDFLAGS
XBS5_ILP32_OFF32_LIBS_CS_XBS5_ILP32_OFF32_LIBS
XBS5_ILP32_OFF32_LINTFLAGS_CS_XBS5_ILP32_OFF32_LINTFLAGS
XBS5_ILP32_OFFBIG_CFLAGS_CS_XBS5_ILP32_OFFBIG_CFLAGS
XBS5_ILP32_OFFBIG_LDFLAGS_CS_XBS5_ILP32_OFFBIG_LDFLAGS
XBS5_ILP32_OFFBIG_LIBS_CS_XBS5_ILP32_OFFBIG_LIBS
XBS5_ILP32_OFFBIG_LINTFLAGS_CS_XBS5_ILPBIG_OFF32_LINTFLAGS
XBS5_LP64_OFF64_CFLAGS_CS_XBS5_LP64_OFF64_CFLAGS
XBS5_LP64_OFF64_LDFLAGS_CS_XBS5_LP64_OFF64_LDFLAGS
XBS5_LP64_OFF64_LIBS_CS_XBS5_LP64_OFF64_LIBS
XBS5_LP64_OFF64_LINTFLAGS_CS_XBS5_LP64_OFF64_LINTFLAGS
XBS5_LPBIG_OFFBIG_CFLAGS_CS_XBS5_LPBIG_OFFBIG_CFLAGS
XBS5_LPBIG_OFFBIG_LDFLAGS_CS_XBS5_LPBIG_OFFBIG_LDFLAGS
XBS5_LPBIG_OFFBIG_LIBS_CS_XBS5_LPBIG_OFFBIG_LIBS
XBS5_LPBIG_OFFBIG_LINTFLAGS_CS_XBS5_LPBIG_OFFBIG_LINTFLAGS

环境变量

下列的环境变量影响 getconf的执行:

LANG为取消设置或空的国际化变量值提供一个缺省值。如果 LANG 被取消设置或空,则将使用来自依赖实现的 | 缺省语言环境的相应值。如果任何一个国际化变量包含一个无效设置,实用程序将象未定义变量义变量来运行。
LC_CALL如果设置为一个非空字符串值,则所有其它国际化变量值会被覆盖。
LC_CTYPE确定将文本数据字节序列解释为字符的语言环境(例如,在参数中,单字节字符与多字节字符相对)。
LC_MESSAGES确定用以影响写入标准错误的诊断消息格式和内容的语言环境。
NLSPATH决定处理 LC_MESSAGES 消息目录的位置。

系统范围配置变量

SystemwideConfiguration 参数指定系统配置变量,其值在整个系统中都可用。有两种系统配置变量:

  • 系统范围配置变量
  • 系统标准配置变量

系统范围配置变量

系统范围配置变量包含系统各部分中的最小值。下列的列表定义系统范围配置变量,这些变量与 getconf 命令一起使用:

_CS_PATHPATH 环境变量值,用以查找命令。
ARG_MAX用于一个 exec 子例程的参数的最大长度(以字节为单位),包含环境数据。
BC_BASE_MAXbc 命令使用的 obase 变量允许的最大值。
BC_DIM_MAXbc 命令所允许的一个数组中的最大元素数。
BC_SCALE_MAXbc 命令使用的 scale 变量允许的最大值。
BC_STRING_MAXbc 命令可接受的字符串常量的最大长度。
CHARCLASS_NAME_MAX字符类名中的最大字节数。
CHAR_BIT类型 character 的位数。
CHAR_MAX类型 character 的最大值。
CHAR_MIN类型 character 的最小值。
CHILD_MAX每个真实用户标识同时打开进程的最大数量。
CLK_TCK由 time 子例程返回的每秒钟时钟计数。
COLL_WEIGHTS_MAX配给在一个语言环境定义文件的 LC_COLLATE 语言环境节中条目的最大权重。
CS_PATHPATH 环境变量值,用以查找命令。
EXPR_NEST_MAX圆括号内可嵌套的最大表达式数,用于 expr 命令。
INT_MAX类型的最大值,类型为 int
INT_MIN类型的最小值,类型为 int
LINE_MAX当实用程序被描述成为处理文本文件时,命令输入行(标准输入或者是其它文件)的最大长度(以字节为单位)。长度包含换行字符的空间。
LONG_BIT类型中的位数,类型为 long int
LONG_MAX类型的最大值,类型为 long int
LONG_MIN类型的最小值,类型为 long int
MB_LEN_MAX在所有支持的语言环境中一个字符的最大字节数。
NGROUPS_MAX每个进程中同时补充的最大组标识数。
NL_ARGMAX在 printf 和 scanf 子例程调用中的数字最大值。
NL_LANGMAX在一个 LANG 名中最大字节数。
NL_MSGMAX最大消息数。
NL_NMAX一个从 N 到 1 整序映射中最大字节数。
NL_SETMAX最大设置数。
NL_TEXTMAX一个消息字符串中最大字节数。
NZERO缺省进程优先级。
OPEN_MAX在进程中可同时打开的最大文件数。
PATH用以查找命令的以冒号相隔的路径前缀的序列。
RE_DUP_MAX当使用间隔符号参数时允许正则表达式重复出现次数的最大值,正如 ed 命令使用的 m 和 n 参数。
SCHAR_MAX类型的最大值,类型为 signed char
SCHAR_MIN类型的最小值,类型为 signed char
SHRT_MAX类型的最大值,类型为 short
SHRT_MIN类型的最小值,类型为 short
SSIZE_MAX一个类型为 ssize_t 的对象的最大值。
STREAM_MAX一个进程可同时打开的流数。
TMP_MAX由 tmpnam 子例程生成的唯一路径名的最小数量。一个应用程序可靠调用 tmpnam子例程的最多次数。
TZNAME_MAX一个时区名支持的最大字节数(非 TZ 环境变量的长度)。
UCHAR_MAX类型的最大值,类型为 unsigned char
UINT_MAX类型的最大值,类型为 unsigned int
ULONG_MAX类型的最大值,类型为 unsigned long int
USHRT_MAX类型的最大值,类型为 unsigned short int
WORD_BIT字或类型 int 中的位数。
KERNEL_BITMODE内核的位方式,32 位或 64 位.
REAL_MEMORY真实内存大小。
HARDWARE_BITMODE计算机硬件的位方式,32 位或 64 位。
MP_CAPABLE计算机微处理器容量。

系统标准配置变量

系统标准配置变量包含由一个特殊系统标准所要求的最小值。_POSIX_POSIX2_ 和 _XOPEN_ 前缀显示变量包含分别由
POSIX 1003.1、POSIX 1003.2 和 X/Open 系统标准要求的系统特性最小值。系统标准是系统满足的用来支持特定系统标准的全系统最小值。实际配置值可能超出这些标准。用于 getconf 命令的这些系统标准配置变量的定义如下:

_POSIX_ARG_MAX用于 exec 子例程的参数的最大长度(以字节为长度),包含环境数据。
_POSIX_CHILD_MAX每个真实用户标识同时打开进程的最大数量。
_POSIX_JOB_CONTROL如果系统支持作业控制,则值为 1。
_POSIX_LINK_MAX到单个文件的最大链接数。
_POSIX_MAX_CANON在终端规范输入队列中的最大字节数。
_POSIX_MAX_INPUT在终端输入队列中允许的最大字节数。
_POSIX_NAME_MAX文件名中的最大字节数(不包含终止空字符)。
_POSIX_NGROUPS_MAX每个进程中同时补充的最大组标识数。
_POSIX_OPEN_MAX在进程中可同时打开的最大文件数。
_POSIX_PATH_MAX路径名中的最大字节数。
_POSIX_PIPE_BUF写入管道时保证成为原子的最大字节数。
_POSIX_SAVED_IDS值为1。每个进程具有保存的 set-user-ID 和保存的 set-group-ID。
_POSIX_SSIZE_MAX可存进一个类型为 ssize_t 对象的最大值。
_POSIX_STREAM_MAX一个进程可同时打开的流数。
_POSIX_TZNAME_MAX一个时区名支持的最大字节数(非 TZ 环境变量的长度)。
_POSIX_VERSION操作系统遵守的 POSIX 1 标准(C 语言绑定)的版本。
_XOPEN_CRYPT如果系统支持 X/Open 加密功能组则值为 1。
_XOPEN_ENH_I18N如果系统支持 X/Open 增强国际化功能组则值为 1。
_XOPEN_SHM如果系统支持 X/Open 共享内存功能组则值为 1。
_XOPEN_VERSION操作系统所遵守的 X/Open 可移植性指南的版本。
_XOPEN_XCU_VERSION操作系统所遵守的 X/Open 命令和实用程序规范的版本。
_XOPEN_XPG2如果系统支持 1987 年 1 月卷 2 的 X/Open 可移植性指南,XVS 系统调用和库,则值为 1,否则为未定义。
_XOPEN_XPG3如果系统支持 1992 年 2 月 的 X/Open 规范,系统接口和头第三版,则缺省值为 1,否则为未定义。
_XOPEN_XPG4如果系统支持 1992 年 7 月 的 X/Open CAE 规范,系统接口和头第 4 版,则值为 1,否则为未定义。
POSIX2_BC_BASE_MAX允许的最大值,用于 obase 变量并使用 bc 命令。
POSIX2_BC_DIM_MAXbc 命令允许数组中的最大元素数。
POSIX2_BC_SCALE_MAX允许的最大值,用于 scale 变量,执行 bc 命令。
POSIX2_BC_STRING_MAX可被 bc 命令接受的字符串常量的最大长度。
POSIX2_CHAR_TERM系统支持至少一个终端类型则值为 1;否则值为 -1。
POSIX2_COLL_WEIGHTS_MAX配给一个条目的最大权重数目,条目在一个语言环境定义文件中的 LC_COLLATE 语言环境变量中。
POSIX2_C_BIND如果系统支持 POSIX 2 中的 C 语言绑定选项,则值为 1;否则,值为-1。
POSIX2_C_DEV如果系统支持 POSIX 2 中的 C 语言开发实用程序则值为 1;否则,值为 -1。
POSIX2_C_VERSION操作系统所遵守的 POSIX 2 标准(C 语言绑定)的版本。
POSIX2_EXPR_NEST_MAX圆括号内可嵌套的最大表达式数,用于 expr 命令。
POSIX2_FORT_DEV如果系统支持 POSIX 2 中的 FORTRAN 开发实用程序选项则值为 1;否则,值为 -1。
POSIX2_FORT_RUN如果系统支持 POSIX 2 中的 FORTRAN 运行时实用程序选项则值为 1;否则,值为 -1。
POSIX2_LINE_MAX当命令被描述成处理文本文件时,一个命令输入行(标准输入或其他文件)的最大字节长度。长度包含换行字符空间。
POSIX2_LOCALEDEF如果系统支持由 localedef 命令创建语言环境,则值为
1;否则值未定义。
POSIX2_RE_DUP_MAX当使用间隔计数参数时正则表达式所允许重复出现的最大值,例如带 m 和 n 参数使用 ed 命令。
POSIX2_SW_DEV系统支持软件开发实用程序选项则值为 1;否则,值为 -1。
POSIX2_UPE如果系统支持 POSIX 2 中用户可移植实用程序选项,则值为 1;否则,值为 -1。
POSIX2_VERSION系统支持的 POSIX 2 标准的最新版本的批准日期。这个日期是一个六位数字,前四位数字表示年份后两位数字表示月份。POSIX 2 标准的不同版本由 IEEE 标准委员会定期批准,批准日期用于区分不同版本。

系统路径配置变量

PathConfiguration 参数指定了系统路径配置变量,该变量值包含在系统中的路径和路径结构信息。下列的列表定义了这些变量:

_POSIX_CHOWN_RESTRICTEDchown() 子例程以适当的特权限制在进程,并且将文件的组标识只更改为进程的有效组标识或辅助组标识之一。如果 PathName 参数引用目录,其返回值应用于除在目录中已存在的或可被创建的目录外的所有文件。
_POSIX_NO_TRUNC路径名长于变量 NAME_MAX 指定的限定值就会产生错误。如果 PathName 参数引用目录,其返回值应用于目录中的文件名。
_POSIX_VDISABLE终端特殊字符,定义在 termios.h 文件中,可使用这一字符值禁用。
LINK_MAX链接一个文件的最大链接数。如果 PathName 参数引用目录,则返回值应用于该目录。
MAX_CANON在终端规范输入行中的最大字节数。
MAX_INPUT在终端输入队列有可用空间的最大字节数。
NAME_MAX文件名中的最大字节数(不包含终止空字符)。如果 PathName 参数引用目录,返回值应用于目录内的文件名。
PATH_MAX路径名中的最大字节数,包含终止空字符。如果 PathName 参数引用目录,返回值为当指定目录是工作目录时的相对路径名的最大长度。
PIPE_BUF当写入管道时保证成为原子的最大字节数。如果这个 PathName 参数指向先进先出或是管道,其返回值应用于引用对象。如果 PathName 参数引用目录,返回值应用于任何已存在的或可在目录内创建的先进先出。
DISK_PARTITION磁盘的物理分区大小。
注:
对于 DISK_PARTITION 路径配置变量,这个 PathName 参数必须指定为之查询信息的磁盘的完整路径。
DISK_SIZE磁盘大小以兆字节为单位。
注:
对于 DISK_SIZE 路径配置变量,这个 PathName 参数必须指定为之查询信息的磁盘的完整路径。

设备变量

DeviceVariable 参数显示了这个 DeviceName 参数是一个设备路径,例如 /dev/hdisk0。给定一个磁盘的路径,则这个 getconf 命令显示这个磁盘的设备名或位置。

DISK_DEVNAME设备名或设备位置。

退出状态

此命令返回下列出口值:

0这个指定变量是有效的并且其当前状态的信息已被成功写入。
>0发生错误。
  1. 显示变量 ARG_MAX 的值,请输入:

    getconf ARG_MAX
  2. 显示所有系统配值变量值,输入:
     getconf -a
  3. 显示变量 NAME_MAX 的值,用于 /usr 目录,请输入:

     
    getconf NAME_MAX /usr
  4. 下列 shell 命令显示怎样处理未指定结果:

    if value=$(getconf PATH_MAX /usr)
         then     if [ "$value" = "undefined" ]
         then
                    echo 
                         The value of PATH_MAX in /usr is undefined.
         else
    
                         The value of PATH_MAX in /usr is $value.
         fi
    else
                    echo 
                         Error in the getconf command.
    fi

示例

  1. 显示变量 ARG_MAX 的值,请输入:

    getconf ARG_MAX
  2. 显示变量 NAME_MAX 的值,用于 /usr 目录,请输入:

    getconf NAME_MAX /usr
  3. 下列 shell 命令显示怎样处理未指定结果:

    if value=$(getconf PATH_MAX /usr)
    then     if [ "$value" = "undefined" ]
         then
                 echo 
                       The value of PATH_MAX in /usr is undefined.
         else
                 echo 
                       The value of PATH_MAX in /usr is $value.
         fi
    else
         echo Error in the getconf command.
    fi
  4. 如果命令:

    getconf _XBS5_ILP32_OFF32 

    没有写入 -1\n 或 undefined\n 到标准输出,那么表单命令:

    getconf -v XBS5_ILP32_OFF32 ... 

    将确定相应于 XBS5_ILP32_OFF32 编译环境的配置变量值。编译环境指定于 c89,扩展描述。

  5. 如果命令:

    getconf _XBS5_ILP32_OFFBIG 

    没有写入 -1\n 或 undefined\n 到标准输出,那么表单命令:

    getconf -v XBS5_ILP32_OFFBIG ... 

    将确定相应于 XBS5_ILP32_OFFBIG 编译环境的配置变量值,编译环境值指定于 c89,扩展描述。

  6. 如果命令:

    getconf _XBS5_LP64_OFF64 

    没有写入 -1\n 或 undefined\n 到标准输出,那么表单命令:

    getconf -v XBS5_LP64_OFF64 ... 

    将确定相应于 XBS5_LP64_OFF64 编译环境的配置变量值,编译环境值指定于 c89,扩展描述。

  7. 如果命令:

    getconf _XBS5_LPBIG_OFFBIG 

    没有写入 -1\n 或 undefined\n 到标准输出,那么如下形式的命令:

    getconf -v _XBS5_LPBIG_OFFBIG 

    将确定相应于在 c89,扩展描述中指定的 XBS5_LPBIG_OFFBIG 编译环境的配值变量值。

  8. 确定磁盘 hdisk0 大小,若是 root 用户,则输入下列:
    getconf DISK_SIZE /dev/hdisk0
  9. 确定实际内存大小,输入下列:
    getconf REAL_MEMORY
  10. 确定是否机器硬件是 32 位或 64 位,则输入下列:
    getconf HARDWARE_BITMODE
  11. 确定是否内核是 32 位或 64 位,则输入下列:
    getconf KERNEL_BITMODE
  12. 确定磁盘 hdisk0 的设备名或位置,则输入下列:
    getconf DEVICE_NAME /dev/hdisk0

文件

/usr/bin/getconf包含一个 getconf 命令。
/usr/include/limits.h定义系统配置变量。
/usr/include/unistd.h定义系统配置变量。

本文由【waitig】发表在等英博客
本文固定链接:gentconf命令解释及用法
欢迎关注本站官方公众号,每日都有干货分享!
等英博客官方公众号
点赞 (0)分享 (0)