【AIX-PS】AIX系統ps命令詳解
本文來自:
ps [ -A ] [ -M ] [ -N ] [ -Z ] [ -a ] [ -d ] [ -e ] [ -f ] [ -k ] [ -l ] [ -F format] [ -o Format ] [ -c Clist ] [ -G Glist ] [ -g Glist ] [ -m ] [ -n NameList ] [ -p Plist ] [ -P ] [ -t Tlist ] [ -U Ulist ] [ -u Ulist ] [ -T pid ] [ -L pidlist ] [ -X ] [ -@ [ WparName ] ]
Berkeley Standards
ps [ a ] [ c ] [ e ] [ ew ] [ eww ] [ ewww ] [ g ] [ n ] [ w ] [ x ] [ l | s | u | v ] [ t tty ] [ X ] [ ProcessNumber ]
Description
The ps command writes the status of active processes and if the -m flag is given, displays the associated kernel threads to standard output. While the -m flag displays threads associated with processes using extra lines, you must use the -o flag with the THREAD field specifier to display extra thread-related columns.
Without flags, the ps command displays information about the current terminal. The -f, -o, l, -l, s, u, and v flags only determine how much information is provided about a process; they do not determine which processes are listed. The l, s, u, and v flags are mutually exclusive.
With the -o flag, the ps command examines memory or the paging area and determines what the command name and parameters were when the process was created. If the ps command cannot find this information, the command name stored in the kernel is displayed in square brackets.
The COLUMNS environment variable overrides the system-selected, horizontal screen size.
The command-line flags that accept a list of parameters (the -o, -G, -g, -p, -t, -U, and -u flags) are limited to 128 items. For example, the -u Ulist flag can specify no more than 128 users.
For cases in which the output of the ps command does not include workload partition ( WPAR) names but does include Project IDs ( PROJECT), User IDs ( UID or USER), or Group IDs ( GID) associated with a process running within a workload partition under the current operating environment, the IDs are preceded by a plus sign (+) to indicate the association with a workload partition. Each workload partition contains its own definition of users, groups, and project IDs that may be different from the IDs defined for the global environment. The -@ option may be specified to include workload partition names in the output.
Depending on the flags used with the ps command, column headings are displayed above the information displayed to standard output. The headings are defined in the following list and the flags that cause these headings to be displayed are shown in parentheses :
- ADDR
- ( -l and l flags) Contains the segment number of the process stack, if normal; if a kernel process, the address of the preprocess data area.
- BND
- ( -o THREAD flag) The logical processor number of the processor to which the kernel thread is bound if any. For a process, this field is displayed if all its threads are bound to the same processor.
- C
- ( -f, l, and -l flags) CPU utilization of process or thread, incremented each time the system clock ticks and the process or thread is found to be running. The value is decayed by the scheduler by dividing it by 2 once per second. For the sched_other policy, CPU utilization is used in determining process scheduling priority. Large values indicate a CPU intensive process and result in lower process priority, whereas small values indicate an I/O intensive process and result in a more favorable priority.
- CMD
- ( -f, -l, and l flags) Contains the command name. Under the -f flag, the ps command tries to determine the current command name and arguments, both of which may be changed asynchronously by the process. These are then displayed. If this fails, the command name is written as it would appear without the -f option in square brackets.
- COMMAND
- (
s,
u, and
v) Contains the command name. The full command name and its parameters are displayed with the
-f flag.
F Field TableFlagsHexadecimal ValueDefinition
SLOAD 0x00000001 Indicates that the process is operating in core memory. SNOSWAP 0x00000002 Indicates that the process cannot be swapped out. STRC 0x00000008 Indicates that the process is being traced. SWTED 0x00000010 Indicates that the process stopped while being traced. SFWTED 0x00000020 Indicates that the process stopped after a call to the forksubroutine, while being traced. SEWTED 0x00000040 Indicates that the process stopped after a call to the execsubroutine, while being traced. SLWTED 0x00000080 Indicates that the process stopped after a call to the load or unload subroutine, while being traced. SFIXPRI 0x00000100 Indicates that the process has a fixed priority, ignoring the pcpu field descriptor. SKPROC 0x00000200 Indicates a Kernel process. SOMASK 0x00000400 Indicates restoration of the old mask after a signal is received. SWAKEONSIG 0x00000800 Indicates that the signal will abort the sleep subroutine. The contents must not be equal to those of the PCATCH flag. The contents of both PCATCH and SWAKEONSIG must be greater than those of PMASK. SUSER 0x00001000 Indicates that the process is in user mode. SLKDONE 0x00002000 Indicates that the process has done locks. STRACING 0x00004000 Indicates that the process is a debugging process. SMPTRACE 0x00008000 Indicates multi-process debugging. SEXIT 0x00010000 Indicates that the process is exiting. SSEL 0x00020000 Indicates that the processor is selecting: wakeup/waiting danger. SORPHANPGRP 0x00040000 Indicates an orphaned process group. SNOCNTLPROC 0x00080000 Indicates that the session leader relinquished the controlling terminal. SPPNOCLDSTOP 0x00100000 Indicates that the SIGHLD signal is not sent to the parent process when a child stops. SEXECED 0x00200000 Indicates that process has been run. SJOBSESS 0x00400000 Indicates that job control was used in the current session. SJOBOFF 0x00800000 Indicates that the process is free from job control. PSIGDELIVERY 0x01000000 Indicates that the process is used by the program-check handler. SRMSHM 0x02000000 Indicates that the process removed shared memory during a call to the exit subroutine. SSLOTFREE 0x04000000 Indicates that the process slot is free. SNOMSG 0x08000000 Indicates that there are no more uprintf subroutine messages. - WPAR
- ( -@ flag) Contains the workload partition name. Under the -@ flag, the ps command displays the name of the workload partition in which the process is running. Specify the -@ flag with the wparname parameter to display the process information.
- DPGSZ
- ( Z flag) The data page size of the process.
- F
- (
-l and
l flags) Some of the more important F field flags (hexadecimal and additive) associated with processes and threads are listed in the following table:
F Field TableFlagsHexadecimal ValueDefinition
SLOAD 0x00000001 Indicates that the process is operating in core memory. SNOSWAP 0x00000002 Indicates that the process cannot be swapped out. STRC 0x00000008 Indicates that the process is being traced. SKPROC 0x00000200 Indicates a kernel process. SEXIT 0x00010000 Indicates that the process is exiting. SLPDATA 0x00020000 Indicates that the process uses large pages. SEXECED 0x00200000 Indicates that the process has been run. SEXECING 0x01000000 Indicates that the process is execing (performing an exec). SPSEARLYALLOC 0x04000000 Indicates that paging space for this process is allocated early. TKTHREAD 0x00001000 Indicates that the thread is a kernel-only thread. Note: You can see the definitions of all process and thread flags by consulting the p_flags and t_flags fields in the /usr/include/sys/proc.h and /usr/include/sys/thread.h files respectively.
- LIM
- ( v flag) The soft limit on memory used, specified through a call to the setrlimit subroutine. If the limit has not been specified, then xx is displayed. If the limit is set to the system limit (unlimited), a value of UNLIM is displayed.
- NI
- ( -l and l flags) The nice value; used in calculating priority for the sched other policy.
- PID
- (all flags) The process ID of the process.
- PGIN
- ( v flag) The number of disk I/Os resulting from references by the process to pages not loaded in core.
- PPID
- ( -f, l, and -l flags) The process ID of the parent process.
- PRI
- ( -l and l flags) The priority of the process or kernel thread; higher numbers mean lower priority.
- PROJECT
- ( -P flag) Project name assigned to the process. Under the current operating environment, the PROJECT and USER fields are not translated to names for processes running within a workload partition. The -U and -u flags only apply to the current operating environment, unless the -@ flag is included with a specific workload partition name. If the -@ flag is used to specify a workload partition other than the current operating environment, and the -U and -u flags are specified, the list of user IDs must be numeric.
- RSS
- ( v flag) The real-memory (resident set) size of the process (in 1 KB units).
- S
- (
-l and
l flags) The state of the process or kernel thread :
For processes:
- O
- Nonexistent
- A
- Active
- W
- Swapped
- I
- Idle (waiting for startup)
- Z
- Canceled
- T
- Stopped
For kernel threads:
- O
- Nonexistent
- R
- Running
- S
- Sleeping
- W
- Swapped
- Z
- Canceled
- T
- Stopped
- SC
- ( -o THREAD flag) The suspend count of the process or kernel thread. For a process, the suspend count is defined as the sum of the kernel threads suspend counts.
- SCH
- ( -o THREAD, sched flag) The scheduling policy for a kernel thread. The policies sched_other, sched_fifo, and sched_rr are respectively displayed using: 0, 1, 2. The scheduling policies is displayed only when a sched flag is specified.
- SIZE
- ( v flag) The virtual size of the data section of the process (in 1 KB units).
- SHMPGSZ
- ( Z flag) The shared memory page size of the process.
- SPGSZ
- ( Z flag) The stack page size of the process.
- SSIZ
- ( s flag) The size of the kernel stack. This value is always 0 (zero) for a multi-threaded process.
- STAT
- (
s,
u, and
v flags) Contains the state of the process:
- 0
- Nonexistent
- A
- Active
- I
- Intermediate
- Z
- Canceled
- T
- Stopped
- K
- Available kernel process
- STIME
- ( -f and u flags) The starting time of the process. The LANG environment variables control the appearance of this field.
- SUBPROJ
- ( -P flag) Subproject Identifier assigned to the process.
- SZ
- ( -l and l flags) The size in 1 KB units of the core image of the process.
- THCNT
- ( -o thcount flag) The number of kernel threads owned by the process.
- TID
- ( -o THREAD flag) The thread ID of the kernel thread.
- TIME
- (all flags) The total runtime for the process. The time is displayed in the format of mm:ss or mmmm:ss if the runtime reaches 100 minutes, which is different from the displayed format if you use the -o time flag.
- TPGSZ
- ( Z flag) The text page size of the process.
- TRS
- ( v flag) The size of resident-set (real memory) of text.
- TSIZ
- ( v flag) The size of text (shared-program) image.
- TTY
- (all flags) The controlling terminal for the process:
- -
- The process is not associated with a terminal.
- ?
- Unknown.
- Number
- The TTY number. For example, the entry 2 indicates TTY2.
- UID
- ( -f, -l, and l flags) The user ID of the process owner. The login name is printed under the -f flag.
- USER
- ( u flag) The login name of the process owner. Under the current operating environment, the PROJECT and USER fields are not translated to names for processes running within a workload partition.
- WCHAN
- ( -l flag) The event for which the process or kernel thread is waiting or sleeping. For a kernel thread, this field is blank if the kernel thread is running. For a process, the wait channel is defined as the wait channel of the sleeping kernel thread if only one kernel thread is sleeping; otherwise a star is displayed.
- WCHAN
- ( l flag) The event on which the process is waiting (an address in the system). A symbol that classifies the address is selected, unless a numerical output is requested.
- %CPU
- ( u and v flags) The percentage of time the process has used the CPU since the process started. This value is computed by dividing the time the process uses the CPU by the elapsed time of the process. In a multi-processor environment, the value is further divided by the number of available CPUs because several threads in the same process can run on different CPUs at the same time. (Because the time base over which this data is computed varies, the sum of all %CPU fields can exceed 100%.)
- %MEM
- ( u and v flags) The percentage of real memory used by this process. The %MEM value tends to exaggerate the cost of a process that is sharing program text with other processes. It does not account for times when multiple copies of a program are run and a copy of the program text is shared by all instances. The size of the text section is accounted for in every instance of the program. This means that if several copies of a program are run, the total %MEM value of all processes could exceed 100%.
- The process can change while the ps command is running. Some data displayed for defunct processes is irrelevant.
- The ps program examines the memory to retrieve the file name and arguments used when the process was created. However, a process can destroy information, making this method of retrieving file name and arguments unreliable.
- The ps program searches the local resources for users and group information.
Flags
The following flags are preceded by a - (minus sign):
Item |
Description |
---|---|
-A | Writes to standard output information about all processes. |
-a | Writes to standard output information about all processes, except the session leaders and processes not associated with a terminal. |
-c Clist | Displays only information about processes assigned to the workload management classes listed in the Clistvariable. The Clist variable is either a comma-separated list of class names or a list of class names enclosed in double quotation marks (" "), which is separated from one another by a comma or by one or more spaces, or both. |
-d | Writes information to standard output about all processes, except the session leaders. |
-e | Writes information to standard output about all processes, except kernel processes. |
-F Format | Same as the -o Format |
-f | Generates a full listing. |
-G Glist | Writes information to standard output only about processes that are in the effective groups listed for the Glist variable. The Glist variable is either a comma-separated list of effective group identifiers, or a list of effective group identifiers enclosed in double quotation marks (" ") and separated from one another by a comma or by one or more spaces. |
-g Glist | Writes information to standard output only about processes that are in the process groups listed for the Glist variable. The Glist variable is either a comma-separated list of process group identifiers or a list of process group identifiers enclosed in double quotation marks (" ") and separated from one another by a comma or by one or more spaces. |
-k | Lists kernel processes. |
-l | Generates a long listing. Also see the l flag. |
-L pidlist | Generates a list of descendants of each and every pid that has been passed to it in the pidlist variable. The pidlist variable is a list of comma-separated process IDs. The list of descendants from all the given pid is printed in the order in which they appear in the process table. |
-M | Lists all 64 bit processes. |
-m | Lists kernel threads as well as processes. Output lines for processes are followed by an additional output line for each kernel thread. This flag does not display thread-specific fields ( bnd, scount, sched, thcount, and tid), unless the appropriate -o Format flag is specified. |
-N | Gathers no thread statistics. With this flag, ps reports those statistics that can be obtained by not traversing through the threads chain for the process. |
-n NameList | Specifies an alternative system name-list file in place of the default. The operating system does not use the -n flag because information is supplied directly to the kernel. |
-o Format | Displays information in the format specified by the
Format variable. Multiple field specifiers can be specified for the
Format variable. The
Format variable is either a comma-separated list of field specifiers or a list of field specifiers enclosed within a set of " " (double-quotation marks) and separated from one another by a comma or by one or more spaces, or both.
Each field specifier has a default header. The default header can be overridden by appending an = (equal sign) followed by the user-defined text for the header. The fields are written in the order specified on the command-line in column format. The field widths are specified by the system to be at least as wide as the default or user-defined header text. If the header text is null (such as if -o user= is specified), the field width is at least as wide as the default header text. If all header fields are null, no header line is written. The following field specifiers are recognized by the system:
|
-o Continued |
|
-o Continued |
Otherwise, multiple fields in a specified format can be displayed by the Format variable, including field descriptors. If field descriptors are used in the Format variable, it must be enclosed in double quotation marks (" "). The following table shows how field descriptors correspond to field specifiers: |
|
Each field specifier has a default header. The default header can be overridden by appending an equal sign (=) followed by the user-defined text for the header. The fields are written in the order specified on the command-line in column format. The field widths are specified by the system to be at least as wide as the default or user-defined header text. If the header text is null (for example,
|
|
Following is the mapping between the default headers and various field specifiers. Every entry in the Default Header column can be overridden by appending an equal sign (=) to the corresponding entry in the Field specifier followed by the user-defined text for the header.
|
-p Plist | Displays only information about processes with the process numbers specified for the Plist variable. The Plist variable is either a comma-separated list of process ID numbers or a list of process ID numbers enclosed in double quotation marks (" ") and separated from one another by a comma or by one or more spaces, or both. |
-P | Displays the Project name, Project origin, and subproject identifier for the project. If the stick bit is set for the process, the project name is preceded by an asterisk (*) character. The Project origin field designates the currently loaded project repository (LOCAL or LDAP). |
-t Tlist | Displays only information about processes associated with the controlling ttys listed in the Tlist variable. The Tlist variable is either a comma-separated list of tty identifiers or a list of tty identifiers enclosed in double quotation marks (" ") and separated from one another by a comma or by one or more spaces, or both. |
-T pid | Displays the process hierarchy rooted at a given pid in a tree format using ASCII art. This flag can be used in combination with the -f, -F, -o, and -l flags. |
-u Ulist | This flag is equivalent to the -U Ulist flag. The -u flag only applies to the current operating environment unless the -@ flag is also specified. If the -@ flag is used to specify a workload partition other than the current operating environment and the -u flag is specified, the list of user IDs must be numeric. |
-U Ulist | Displays only information about processes with the user ID numbers or login names specified for the Ulistvariable. The Ulist variable is either a comma-separated list of user IDs or a list of user IDs enclosed in double quotation marks (" ") and separated from one another by a comma and one or more spaces. The -Uflag only applies to the current operating environment unless the -@ flag is also specified. If the -@ flag is used to specify a workload partition other than the current operating environment and the -U flag is specified, the list of user IDs must be numeric. In the listing, the ps command displays the numerical user ID unless the -f flag is used; then the command displays the login name. This flag is equivalent to the -u Ulist flag. See also the u flag. |
-X | Prints all available characters of each user/group name instead of truncating to the first eight characters. |
-Z | Displays the page size settings of processes.
|
-@ [ WparName ] | Displays the process information that is associated with the workload partition WparName. If you do not specify the WparName parameter, the process information for all workload partitions is displayed. Workload partition information is displayed for all processes. You must specify other flags to the ps command to determine which process information to be displayed. |
Options
The following options are not preceded by a minus sign (-):
Item |
Description |
---|---|
a | Displays information about all processes with terminals (ordinarily only the own processes of the user are displayed). |
c | Displays the command name, as stored internally in the system for purposes of accounting, rather than the command parameters, which are kept in the process address space. |
e | Displays the environment as well as the parameters to the command, up to a limit of 80 characters. |
ew | Wraps the display from the e flag one extra line. |
eww | Wraps the display from the e flag and displays the ENV list until the flag reaches the LINE_MAX value. |
ewww | Wraps the display from the e flag and displays the ENV list until the flag reaches the INT_MAX value. |
g | Displays all processes. |
l | Displays a long listing having the F, S, UID, PID, PPID, C, PRI, NI, ADDR, SZ, PSS, WCHAN, TTY, TIME, and CMD fields. |
n | Displays numerical output. In a long listing, the WCHAN field is printed numerically rather than symbolically. In a user listing, the USER field is replaced by a UID field. |
s | Displays the size (SSIZ) of the kernel stack of each process (for use by system maintainers) in the basic output format. This value is always 0 (zero) for a multi-threaded process. |
t tty | Displays processes whose controlling tty is the value of the tty variable, which should be specified as printed by the ps command; that is, 0 for terminal /dev/tty/0, lft0 for /dev/lft0, and pts/2 for /dev/pts/2. |
u | Displays user-oriented output. This includes the USER, PID, %CPU, %MEM, SZ, RSS, TTY, STAT, STIME, TIME, and COMMANDfields. |
v | Displays the PGIN, SIZE, RSS, LIM, TSIZ, TRS, %CPU, %MEM fields. |
w | Specifies a wide-column format for output (132 columns rather than 80). If repeated, (for example, ww), uses arbitrarily wide output. This information is used to decide how much of long commands to print. |
x | Displays processes without a controlling terminal in addition to processes with a controlling terminal. |
X | Prints the full user name or group name. The name is not truncated. |
Exit Status
This command returns the following exit values:
Item |
Description |
---|---|
0 | Successful completion. |
>0 | An error occurred. |
Security
Attention RBAC users and Trusted AIX users: This command can perform privileged operations. Only privileged users can run privileged operations. For more information about authorizations and privileges, see Privileged Command Database in Security. For a list of privileges and the authorizations associated with this command, see the lssecattr command or the getcmdattr subcommand.
Examples
- To display all processes, type:
- To list processes owned by specific users, type:
- To list processes that are associated with the
/dev/console and
/dev/tty1 ttys, type:
- To list processes not associated with a terminal, type:
- To display a specified format with field specifiers, type:
- To display a specified format with field descriptors, type:
- To display information about processes and kernel threads controlled by the current terminal, type:
- To display information about all processes and kernel threads, type:
- To list all the 64-bit processes, type:
- To display the project assignment details for the processes, type:
- To display the page size settings of the processes, type: The output is like:
Files
Item |
Description |
---|---|
/ usr/ bin/ ps | Contains the ps command. |
Using the ps command in Performance management.
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/29487349/viewspace-2767967/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- Linux ps命令詳解,Linux檢視程序。Linux
- linux系統awk命令使用詳解Linux
- CentOS 系統常用命令詳解CentOS
- AIX系統日誌AI
- Linux檢視程序命令ps和top示例詳解Linux
- Linux下 netstat ps kill 命令詳解及常用命令收集Linux
- Linux系統檢視log日誌命令詳解!Linux
- aix檔案系統擴容AI
- AIX作業系統安全加固AI作業系統
- AIX相關管理命令AI
- Unix檔案系統和pwd命令實現詳解
- 作業系統(AIX)雙因素身份認證解決方案作業系統AI
- AIX系統擴vg操作步驟AI
- Cnetos7系統---檔案壓縮與解壓命令詳解。
- Centos7系統---檔案壓縮與解壓命令詳解。CentOS
- Unix系統中的dot命令的使用方法詳解
- Linux系統常見檔案大小常用的命令詳解!Linux
- Linux系統檢視檔案地址常用的命令詳解!Linux
- 【Linux】ps -ef|grep詳解Linux
- IBM AIX儲存層結構分析+aix常用命令IBMAI
- 【資訊採集】IBM AIX系統硬體資訊檢視命令(shell指令碼)IBMAI指令碼
- ps命令
- 各大作業系統AIX/HPUX/Solaris/Linux下的系統日誌作業系統AILinux
- Linux程式之如何檢視程式詳情?(ps命令)Linux
- golang 執行系統命令 ps aux | grep "xxxx",總是異常退出GolangUX
- Dockerfile 命令詳解Docker
- NPM命令詳解NPM
- echo命令詳解
- Linuxtcpdump命令詳解LinuxTCP
- w命令詳解
- getsebool命令詳解
- tcpdump命令詳解TCP
- GCC命令詳解GC
- `find` 命令詳解
- Linux at命令詳解Linux
- netstat命令詳解
- 硬貨!Zabbix監控AIX系統服務案例AI
- 交易系統:線上交易系統流程詳解