Monitoring and Performance
It is often necessary to monitor your systems to determine the CPU, memory,
disk or network load. There are several tools available on Solaris to aid in this
monitoring and analysis. Along with the tools listed in this chapter there are
several resources for DTrace scripts available that can aid system monitoring
and performance tuning. The OpenSolaris DTrace community1 is a good
source for these scripts.
This chapter will look at a few of the available tools and their usage.
Topics Covered
• Processors
• Memory
• Network
• Disks, Volumes and File Systems
• System and User Processes
• Input/Output
Processors
Information on the current processors in the system can be retrieved using the
psrinfo command. An example of the psrinfo output can be seen in Figure 9.1.
Figure 9.1: psrinfo and psrinfo -v
# psrinfo
0 on-line since 09/28/2006 19:49:33
# psrinfo -v
Status of virtual processor 0 as of: 09/29/2006 02:06:34
on-line since 09/28/2006 19:49:33.
The i386 processor operates at 1733 MHz, and has an i387 compatible floating
point processor.
The mpstat command can be used to gather per-processor statistics on the
system. The output data will contain one line per processor. Figure 9.2 shows
example output from mpstat.
Figure 9.2: mpstat 1 3 output
# mpstat 1 3
CPU minf mjf xcal intr ithr csw icsw migr smtx srw syscl usr sys wt idl
0 1305 3 0 394 294 403 38 0 0 0 1554 7 3 0 90
0 10 0 0 358 258 205 0 0 0 0 250 1 1 0 98
0 0 0 0 345 245 186 0 0 0 0 195 1 0 0 99
A field of note in the mpstat output is xcal, if you have multiple CPUs. This
will be the number of inter-processor cross-calls. csw is the number of context
switches. syscl is the number of system calls that happened on the processor.
usr, sys and idl give the amount of user time, system time and idle time
respectively. The wt column is a legacy artifact and will always return 0 on
Solaris 10.
The kstat command can also be used to gather information on the processors.
By providing the -m cpu option to kstat you will retrieve all the CPU
information. Figure 9.3 shows an example of this usage.
Figure 9.3: kstat -m cpu output
# kstat -m cpu
module: cpu instance: 0
name: intrstat class: misc
crtime 6.573712134
level-1-count 1214737
level-1-time 3558707908
level-10-count 2364949
Memory
The vmstat command can be used to display information on the system's
virtual memory subsystem. vmstat gives information on the current swap and
memory, page faults, disk stats and fault information. Figure 9.4 shows
example vmstat output.
Figure 9.4: vmstat 2 5
# vmstat 2 5
kthr memory page disk faults cpu
r b w swap free re mf pi po fr de sr cd f0 s0 -- in sy cs us sy id
0 0 0 1998572 1101884 8 29 14 0 1 0 35 8 0 0 0 397 865 412 5 1 94
0 0 0 1913292 1014728 0 22 6 0 0 0 0 0 0 0 0 364 204 207 1 0 99
0 0 0 1913292 1014728 0 0 0 0 0 0 0 0 0 0 0 356 162 184 1 0 99
kstat can be used to gather memory information. The memory module is
vmem. Figure 9.5 shows example output.
Figure 9.5: kstat -m vmem
# kstat -m vmem
module: vmem instance: 1
name: heap class: vmem
alloc 4632
contains 0
contains_search 0
crtime 0
Network
The netstat command can be used to gather network status information.
netstat can retrieve information on the active network sockets, various network
data structures, STREAMS memory statistics, interface states, routing tables
and DHCP information.
You can use kstat to query information on each network interface driver in the
system. In my case, I'm using the bge driver. Figure 9.6 is an example of the
output.
Figure 9.6: kstat -m bge
# kstat -m bge
module: bge instance: 0
name: bge0 class: net
brdcstrcv 16059
brdcstxmt 14
collisions 65
crtime 128.886063641
ierrors 0
ifspeed 100000000
ipackets 33976
Disks, Volumes and File Systems
The df command displays information on the size, used and available space of
the mounted le systems. Figure 9.7 shows example df output.
Figure 9.7: df -h
# df -h
Filesystem size used avail capacity Mounted on
/dev/dsk/c0d0s0 9.6G 3.1G 6.4G 33% /
/devices 0K 0K 0K 0% /devices
ctfs 0K 0K 0K 0% /system/contract
The du command can be to summarize disk usage information. du will output
the size of each file and each directory as it walks the file system from the
given starting directory.
metastat can be used to display metadevice or hot spare pool information.
System and User Processes
System information can be gathered with the prstat command. prstat shows
process and thread information. prstat is similar to the top command. top is
also available for Solaris as part of the Companion CD. Figure 9.8 shows
example output from prstat.
Figure 9.8: prstat
PID USERNAME SIZE RSS STATE PRI NICE TIME CPU PROCESS/
NLWP
533 dj2 36M 62M sleep 59 0 0:03:45 3.8% Xorg/1
627 dj2 62M 17M run 49 0 0:00:16 0.5% gnome-terminal/2
577 dj2 17M 11M sleep 59 0 0:00:41 0.3% enlightenment/1
873 dj2 3972K 2740K sleep 59 0 0:00:00 0.2% vim/1
Input/Output
The iostat command can be used to display information on the di erent IO
devices in the system. This can include hard drives, TTY devices, NFS mounts
and other devices. Example iostat output can be seen in 9.9.
Figure 9.9: iostat 2 5
# iostat 2 5
tty cmdk0 sd0 nfs1 nfs2 cpu
tin tout kps tps serv kps tps serv kps tps serv kps tps serv us sy wt id
1 140 48 8 8 0 0 0 0 0 0 0 0 0 5 1 0 94
0 117 0 0 0 0 0 0 0 0 0 0 0 0 1 0 0 99
0 40 0 0 0 0 0 0 0 0 0 0 0 0 1 0 0 99