Chapter 35 Managing Processes (Tasks)
This chapter describes the procedures for managing system processes. This is a list of the step-by-step instructions in this chapter.
Displaying Information About Processes
This section describes commands used to manage process information.
The ps Command
The ps command enables you to check the status of active processes on a system, as well as display technical information about the processes. This data is useful for such administrative tasks as determining how to set process priorities.
Depending on which options you use, ps reports the following information:
The table below describes some of the fields reported by the ps command. The fields displayed depend on which option you choose. See ps(1)
for a description of all available options.
Table 35-1 Summary of Fields in
ps Reports
|
Field
|
Description
|
|
UID
|
The effective user ID of the process's owner.
|
|
PID
|
The process ID.
|
|
PPID
|
The parent process's ID.
|
|
C
|
The processor utilization for scheduling. This field is not displayed when the -c option is used.
|
|
CLS
|
The scheduling class to which the process belongs: real-time, system, or timesharing. This field is included only with the -c option.
|
|
PRI
|
The kernel thread's scheduling priority. Higher numbers mean higher priority.
|
|
NI
|
The process's nice number, which contributes to its scheduling priority. Making a process "nicer" means lowering its priority.
|
|
ADDR
|
The address of the proc structure.
|
|
SZ
|
The virtual address size of the process.
|
|
WCHAN
|
The address of an event or lock for which the process is sleeping.
|
|
STIME
|
The starting time of the process (in hours, minutes, and seconds).
|
|
TTY
|
The terminal from which the process (or its parent) was started. A question mark indicates there is no controlling terminal.
|
|
TIME
|
The total amount of CPU time used by the process since it began.
|
|
CMD
|
The command that generated the process.
|
How to List Processes
To list all the processes being executed on a system, use the ps command.
|
ps
|
Displays only the processes associated with your login session.
|
|
-ef
|
Displays full information about all the processes being executed on the system.
|
Example--Listing Processes
The following example shows output from the ps command when no options are used.
$ ps
PID TTY TIME COMD
1664 pts/4 0:06 csh
2081 pts/4 0:00 ps
|
The following example shows output from ps -ef. This shows that the first process executed when the system boots is sched (the swapper) followed by the init process, pageout, and so on.
$ ps -ef
UID PID PPID C STIME TTY TIME CMD
root 0 0 0 May 05 ? 0:04 sched
root 1 0 0 May 05 ? 10:48 /etc/init -
root 2 0 0 May 05 ? 0:00 pageout
root 3 0 0 May 05 ? 43:21 fsflush
root 238 1 0 May 05 ? 0:00 /usr/lib/saf/sac -t 300
root 115 1 0 May 05 ? 0:10 /usr/sbin/rpcbind
root 158 1 0 May 05 ? 0:00 /usr/lib/autofs/autom...
root 134 1 0 May 05 ? 0:12 /usr/sbin/inetd -s
root 107 1 0 May 05 ? 11:49 /usr/sbin/in.routed -q
root 117 1 5 May 05 ? 899:32 /usr/sbin/keyserv
root 125 1 0 May 05 ? 0:00 /usr/sbin/kerbd
root 123 1 0 May 05 ? 4:17 /usr/sbin/nis_cachemgr
daemon 137 1 0 May 05 ? 0:00 /usr/lib/nfs/statd
root 139 1 0 May 05 ? 0:02 /usr/lib/nfs/lockd
root 159 1 50 May 05 ? 8243:36 /usr/sbin/automount
root 162 1 0 May 05 ? 0:07 /usr/sbin/syslogd
root 181 1 0 May 05 ? 0:03 /usr/sbin/nscd...
root 169 1 0 May 05 ? 5:09 /usr/sbin/cron
root 191 1 0 May 05 ? 0:00 /usr/lib/lpsched
root 210 1 0 May 05 ? 0:01 /usr/sbin/vold
root 200 1 0 May 05 ? 0:08 /usr/lib/sendmail -bd -q1h
root 4942 1 0 May 17 console 0:00 /usr/lib/saf/ttymon...
root 208 1 0 May 05 ? 0:00 /usr/lib/utmpd
root 241 238 0 May 05 ? 0:00 /usr/lib/saf/ttymon
root 5748 134 0 17:09:49 ? 0:01 in.rlogind
root 5750 5748 0 17:09:52 pts/0 0:00 -sh
root 5770 5750 2 17:23:39 pts/0 0:00 ps -ef
|
The /proc File System and Commands
In addition, process tools are available in the /usr/proc/bin directory that display highly detailed information about the processes listed in the /proc directory, also known as the process file system (PROCFS). Images of active processes are stored here
by their process ID number.
The process tools are similar to some options of the ps command, except that the output provided by the tools is more detailed. In general, the process tools:
-
Display more details about processes, such as fstat and fcntl information, working directories, and trees of parent and child processes
-
Provide control over processes, allowing users to stop or resume them
Displaying Information About Processes (/proc Tools)
You can display detailed, technical information about active processes by using some of the process tool commands contained in /usr/proc/bin. The table below lists these process tools. Refer to proc(1) for more information.
Table 35-2
/usr/proc/bin Process Tools That Display Information
|
Process Tool
|
What It Displays
|
|
pcred
|
Credentials
|
|
pfiles
|
fstat and fcntl information for open files in a process
|
|
pflags
|
/proc tracing flags, pending and held signals, and other status information
|
|
pldd
|
Dynamic libraries linked into a process
|
|
pmap
|
Address space map
|
|
psig
|
Signal actions
|
|
pstack
|
Hex+symbolic stack trace
|
|
ptime
|
Process time using microstate accounting
|
|
ptree
|
Process trees that contain the process
|
|
pwait
|
Status information after a process terminates
|
|
pwdx
|
Current working directory for a process
|
Note -
To avoid typing long command names, add the process tool directory to your PATH variable. This enables you to run process tools by entering only the last part of each file name (for example, pwdx instead of /usr/proc/bin/pwdx).
How to Display Information About Processes
-
(Optional) Use output from the pgrep command to obtain the identification number of the process you want to display more information about.
|
process
|
Name of the process you want to display more information about.
|
The process identification number is in the first column of the output.
-
Use the appropriate /usr/bin/proc command to display the information you need.
# /usr/proc/bin/pcommand pid
|
|
pcommand
|
Process tool command you want to run. Table 35-2 lists these commands.
|
|
pid
|
Identification number of a process.
|
Examples--Displaying Information About Processes
The following example shows how to use process tool commands to display more information about an lpsched process. First, the /usr/proc/bin path is defined to avoid typing long process tool commands. Next, the identification number for lpsched
is obtained. Finally, output from three process tool commands is shown.
# PATH=$PATH:/usr/proc/bin
# export PATH 1
# ps -e | grep lpsched 2
207 ? 0:00 /usr/lib/lpsched
# pwdx 191 3
207: /
# ptree 191 4
207 /usr/lib/lpsched
# pfiles 191 5
207: /usr/lib/lpsched
Current rlimit: 4096 file descriptors
0: S_IFIFO mode:0000 dev:179,0 ino:70 uid:0 gid:0 size:0
O_RDWR
1: S_IFIFO mode:0000 dev:179,0 ino:70 uid:0 gid:0 size:0
O_RDWR
3: S_IFCHR mode:0666 dev:32,8 ino:11446 uid:0 gid:3 rdev:21,0
O_WRONLY FD_CLOEXEC
4: S_IFDOOR mode:0444 dev:183,0 ino:59515 uid:0 gid:0 size:0
O_RDONLY|O_LARGEFILE FD_CLOEXEC door to nscd[201]
5: S_IFREG mode:0664 dev:32,9 ino:1330 uid:71 gid:8 size:0
O_WRONLY
|
-
Adds the /usr/proc/bin directory to the PATH variable.
-
Obtains the process identification number for lpsched.
-
Displays the current working directory for lpsched.
-
Displays the process tree containing lpsched.
-
Displays fstat and fcntl information.
The following example shows output from the pwait command, which waits until a process terminates, then displays information about what happened. The following example shows output from the pwait command after a Command Tool window was exited.
$ ps -e | grep cmdtool
273 console 0:01 cmdtool
277 console 0:01 cmdtool
281 console 0:01 cmdtool
$ pwait -v 281
281: terminated, wait status 0x0000
|
Controlling Processes (/proc Tools)
You can control some aspects of processes by using some of the process tools contained in /usr/proc/bin. The table below lists these process tools. Refer to proc(1) for detailed information about process tools.
Table 35-3 Process Tools
|
Tools That Control Processes
|
What the Tools Do
|
| | |
|
/usr/proc/bin/pstop pid
|
Stops the process
|
|
/usr/proc/bin/prun pid
|
Restarts the process
|
|
/usr/proc/bin/ptime pid
|
Times the process using microstate accounting
|
|
/usr/proc/bin/pwait [-v] pid
|
Waits for specified processes to terminate
|
| | |
|
Tools That Display Process Details
|
What the Tools Display
|
| | |
|
/usr/proc/bin/pcred pid
|
Credentials
|
|
/usr/proc/bin/pfiles pid
|
fstat and fcntl information for open files
|
|
/usr/proc/bin/pflags pid
|
/proc tracing flags, pending and held signals, and other status information for each lwp
|
|
/usr/proc/bin/pldd pid
|
Dynamic libraries linked into each process
|
|
/usr/proc/bin/pmap pid
|
Address space map
|
|
/usr/proc/bin/psig pid
|
Signal actions
|
|
/usr/proc/bin/pstack pid
|
Hex+symbolic stack trace for each lwp
|
|
/usr/proc/bin/ptree pid
|
Process trees containing specified pids
|
|
/usr/proc/bin/pwdx pid
|
Current working directory
|
In these commands, pid is a process identification number. You can obtain this number by using the ps -ef command.
Chapter 35, Managing Processes (Tasks) describes how to use the process tool commands to perform selected system administration tasks, such as displaying details about processes, and starting and stopping them. A more detailed description of the process tools can be found in proc(1).
If a process becomes trapped in an endless loop, or if it takes too long to execute, you may want to stop (kill) the process. See Chapter 35, Managing Processes (Tasks) for more information about stopping processes using the pkill command.
The previous flat /proc file system has been restructured into a directory hierarchy that contains additional sub-directories for state information and control functions.
It also provides a watchpoint facility that is used to remap read/write permissions on the individual pages of a process's address space. This facility has no restrictions and is MT-safe.
The new /proc file structure provides complete binary compatibility with the old /proc interface except that the new watchpoint facility cannot be used with the old interface.
Debugging tools have been modified to use /proc's new watchpoint facility, which means the entire watchpoint process is faster.
The following restrictions have been removed when setting watchpoints using the dbx debugging tool:
See proc(4), core(4), and adb(1) for more information.
Note -
To avoid typing long command names, add the process tool directory to your PATH variable. This allows you to run process tools by entering only the last part of each file name (for example, prun instead of /usr/proc/bin/prun).
How to Control Processes
-
(Optional) Use output from the ps command to obtain the identification number of the process you want to display more information about.
|
process
|
Name of the process you want to display more information about.
|
The process identification number is in the first column of the output.
-
Use the appropriate /usr/proc/bin command to control the process.
# /usr/proc/bin/pcommand PID
|
|
pcommand
|
Process tool command you want to run. Table 35-3 lists these commands.
|
|
PID
|
Identification number of a process.
|
-
Verify the process status using the ps command.
Example--Controlling Processes
The following example shows how to use process tools to stop and restart Print Tool.
# PATH=$PATH:/usr/proc/bin
# export PATH 1
# ps -e | grep print* 2
264 console 0:03 printtool
# pstop 264 3
# prun 264 4
# ps | grep 264
264 console 0:03 printtool
#
|
-
Adds the /usr/proc/bin directory to the PATH variable.
-
Obtains the process identification number for Print Tool.
-
Stops the Print Tool process.
-
Restarts the Print Tool process.
Killing a Process (pkill)
Sometimes it is necessary to stop (kill) a process. The process may be in an endless loop, or you may have started a large job that you want to stop before it is completed. You can kill any process that you own, and superuser can kill any processes in the system except for those with process IDs 0, 1, 2, 3, and 4.
Refer to pkill(1) for more detailed information.
How to Kill a Process
-
(Optional) To kill a process belonging to another user, become superuser.
-
(Optional) Use output from the pgrep command to obtain the identification number of the process you want to display more information about.
|
process
|
Name of the process you want to display more information about.
|
The process identification number is in the first column of the output.
-
Use the pkill command to stop the process.
|
-9
|
Ensures that the process terminates promptly.
|
|
PID . . .
|
ID of the process or processes to stop.
|
-
Use the pgrep command to verify that the process has been stopped.
Managing Process Class Information
The listing below shows which classes are configured on your system, and the user priority range for the timesharing class. The possible classes are:
-
System (SYS)
-
Interactive (IA)
-
Real-time (RT)
-
Timesharing (TS)
-
The user-supplied priority ranges from -20 to +20.
-
The priority of a process is inherited from the parent process. This is referred to as the user-mode priority.
-
The system looks up the user-mode priority in the timesharing dispatch parameter table and adds in any nice or priocntl (user-supplied) priority and ensures a 0-59 range to create a global priority.
Changing the Scheduling Priority of Processes With priocntl
The scheduling priority of a process is the priority it is assigned by the process scheduler, according to scheduling policies. The dispadmin command lists the default scheduling policies.
The priocntl(1) command can be used to assign processes to a priority class and to manage process priorities. See the section called "How to Designate a Process Priority"
for instructions on using the priocntl command to manage processes.
How to Display Basic Information About Process Classes
You can display process class and scheduling parameters with the priocntl -l command.
Example--Getting Basic Information About Process Classes
The following example shows output from the priocntl -l command.
# priocntl -l
CONFIGURED CLASSES
==================
SYS (System Class)
TS (Time Sharing)
Configured TS User Priority Range: -60 through 60
IA (Interactive)
Configured IA User Priority Range: -60 through 60
RT (Real Time)
Maximum Configured RT Priority: 59
|
How to Display the Global Priority of a Process
You can display the global priority of a process by using the ps command.
The global priority is listed under the PRI column.
Example--Displaying the Global Priority of a Process
The following example shows output from ps -ecl. Data in the PRI column show that pageout has the highest priority, while sh has the lowest.
$ ps -ecl
F S UID PID PPID CLS PRI ADDR SZ WCHAN TTY TIME COMD
19 T 0 0 0 SYS 96 f00d05a8 0 ? 0:03 sched
8 S 0 1 0 TS 50 ff0f4678 185 ff0f4848 ? 36:51 init
19 S 0 2 0 SYS 98 ff0f4018 0 f00c645c ? 0:01 pageout
19 S 0 3 0 SYS 60 ff0f5998 0 f00d0c68 ? 241:01 fsflush
8 S 0 269 1 TS 58 ff0f5338 303 ff49837e ? 0:07 sac
8 S 0 204 1 TS 43 ff2f6008 50 ff2f606e console 0:02 sh
|
How to Designate a Process Priority
-
Become superuser.
-
Start a process with a designated priority.
# priocntl -e -c class -m userlimit -p pri command_name
|
|
-e
|
Executes the command.
|
|
-c class
|
Specifies the class within which to run the process. The default classes are TS (timesharing) or RT (real-time).
|
|
-m userlimit
|
Specifies the maximum amount you can raise or lower your priority, when using the -p option.
|
|
-p pri command_name
|
Lets you specify the relative priority in the RT class, for a real-time thread. For a timesharing process, the -p option lets
you specify the user-supplied priority which ranges from -20 to +20.
|
-
Verify the process status by using the ps -ecl command.
# ps -ecl | grep command_name
|
Example--Designating a Priority
The following example starts the find command with the highest possible user-supplied priority.
# priocntl -e -c TS -m 20 -p 20 find . -name core -print
# ps -ecl | grep find
|
How to Change Scheduling Parameters of a Timeshare Process
-
Become superuser.
-
Change the scheduling parameter of a running timeshare process.
# priocntl -s -m userlimit [-p userpriority] -i idtype idlist
|
|
-s
|
Lets you set the upper limit on the user priority range and change the current priority.
|
|
-m userlimit
|
Specifies the maximum amount you can raise or lower your priority, when using the -p option.
|
|
-p userpriority
|
Allows you to designate a priority.
|
|
-iidtype idlist
|
Uses a combination of idtype and idlist to identify the process. The idtype specifies the type of ID, such as PID or UID.
|
-
Verify the process status by using the ps -ecl command.
Example--Changing Scheduling Parameters of a Timeshare Process
The following example executes a command with a 500-millisecond time slice, a priority of 20 in the RT class, and a global priority of 120.
# priocntl -e -c RT -t 500 -p 20 myprog
# ps -ecl | grep myprog
|
How to Change the Class of a Process
-
(Optional) Become superuser.
Note -
You must be superuser or working in a real-time shell to change processes from, or to, real-time processes.
-
Change the class of a process.
# priocntl -s -c class -i idtype idlist
|
|
-s
|
Lets you set the upper limit on the user priority range and change the current priority.
|
|
-c class
|
Specifies the class, TS or RT, to which you are changing the process.
|
|
-i idtype idlist
|
Uses a combination of idtype and idlist to identify the process.
The idtype specifies the type of ID, such as PID or UID.
|
-
Verify the process status by using the ps -ecl command.
Example--Changing the Class of a Process
The following example changes all the processes belonging to user 15249 to real-time processes.
# priocntl -s -c RT -i uid 15249
# ps -ecl | grep 15249
|
Note -
If, as superuser, you change a user process to the real-time class, the user cannot subsequently change the real-time scheduling parameters (using priocntl -s).
Changing the Priority of a Timesharing Process With nice
The nice(1) command is only supported for backward compatibility to previous Solaris releases. The priocntl command provides
more flexibility in managing processes.
The priority of a process is determined by the policies of its scheduling class, and by its nice number. Each timesharing process has a global priority which is calculated by adding the user-supplied priority, which can be influenced by the nice or priocntl commands, and the system-calculated priority.
The execution priority number of a process is assigned by the operating system, and is determined by several factors, including its schedule class, how much CPU time it has used, and (in the case of a timesharing process) its nice number.
Each timesharing process starts with a default nice number, which it inherits from its parent process. The nice number is shown in the NI column of the ps report.
A user can lower the priority of a process by increasing its user-supplied priority. But only the superuser can lower a nice number to increase the priority of a process. This is to prevent users from increasing the priorities of their own processes, thereby monopolizing a greater
share of the CPU.
Nice numbers range between 0 and +40, with 0 representing the highest priority. The default value is 20. Two versions of the command are available, the standard version, /usr/bin/nice, and a version that is part of the C shell.
How to Change the Priority of a Process
You can raise or lower the priority of a command or a process by changing the nice number. To lower the priority of a process:
|
/usr/bin/nice command_name
|
Increase the nice number by four units (the default)
|
|
/usr/bin/nice +4 command_name
|
Increase the nice number by four units
|
|
/usr/bin/nice -10 command_name
|
Increase the nice number by ten units
|
The first and second commands increase the nice number by four units (the default); and the third command increases the nice by ten units, lowering the priority of the process.
The following commands raise the priority of the command by lowering the nice number.
To raise the priority of a process:
|
/usr/bin/nice -10 command_name
|
Raises the priority of the command by lowering the nice number
|
|
/usr/bin/nice - -10 command_name
|
Raises the priority of the command by lowering the nice number. The first minus sign is the option sign, and
the second minus sign indicates a negative number.
|
The above commands raise the priority of the command, command_name, by lowering the nice number. Note that in the second case, the two minus signs are required.
Process Troubleshooting
Here are some tips on obvious problems you may find:
-
Look for several identical jobs owned by the same user. This may come as a result of running a script that starts a lot of background jobs without waiting for any of the jobs to finish.
-
Look for a process that has accumulated a large amount of CPU time. You'll see this by looking at the TIME field. Possibly, the process is in an endless loop.
-
Look for a process running with a priority that is too high. Type ps -c to see the CLS field, which displays the scheduler class of each process. A process executing as a real-time (RT) process can monopolize
the CPU. Or look for a timeshare (TS) process with a high nice value. A user with superuser privileges may have bumped up the priorities of this process. The system administrator can lower the priority by using the nice command.
-
Look for a runaway process--one that progressively uses more and more CPU time. You can see it happening by looking at the time when the process started (STIME) and by watching the cumulation of CPU time (TIME) for awhile.