]> CyberLeo.Net >> Repos - FreeBSD/FreeBSD.git/blob - usr.bin/vmstat/vmstat.8
Merge llvm trunk r321414 to contrib/llvm.
[FreeBSD/FreeBSD.git] / usr.bin / vmstat / vmstat.8
1 .\" Copyright (c) 1986, 1993
2 .\"     The Regents of the University of California.  All rights reserved.
3 .\"
4 .\" Redistribution and use in source and binary forms, with or without
5 .\" modification, are permitted provided that the following conditions
6 .\" are met:
7 .\" 1. Redistributions of source code must retain the above copyright
8 .\"    notice, this list of conditions and the following disclaimer.
9 .\" 2. Redistributions in binary form must reproduce the above copyright
10 .\"    notice, this list of conditions and the following disclaimer in the
11 .\"    documentation and/or other materials provided with the distribution.
12 .\" 3. Neither the name of the University nor the names of its contributors
13 .\"    may be used to endorse or promote products derived from this software
14 .\"    without specific prior written permission.
15 .\"
16 .\" THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
17 .\" ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
18 .\" IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
19 .\" ARE DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
20 .\" FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
21 .\" DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
22 .\" OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
23 .\" HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
24 .\" LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
25 .\" OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
26 .\" SUCH DAMAGE.
27 .\"
28 .\"     @(#)vmstat.8    8.1 (Berkeley) 6/6/93
29 .\" $FreeBSD$
30 .\"
31 .Dd November 19, 2015
32 .Dt VMSTAT 8
33 .Os
34 .Sh NAME
35 .Nm vmstat
36 .Nd report virtual memory statistics
37 .Sh SYNOPSIS
38 .Nm
39 .\" .Op Fl fimst
40 .Op Fl -libxo
41 .Op Fl afHhimoPsz
42 .Op Fl M Ar core Op Fl N Ar system
43 .Op Fl c Ar count
44 .Op Fl n Ar devs
45 .Oo
46 .Fl p
47 .Sm off
48 .Ar type , if , pass
49 .Sm on
50 .Oc
51 .Op Fl w Ar wait
52 .Op Ar disks ...
53 .Op wait Op count
54 .Sh DESCRIPTION
55 The
56 .Nm
57 utility reports certain kernel statistics kept about process, virtual memory,
58 disk, trap and cpu activity.
59 .Pp
60 If the
61 .Fl M
62 option is not specified, information is obtained from
63 the currently running kernel via the
64 .Xr sysctl 3
65 interface.
66 Otherwise, information is read from the specified core file,
67 using the name list from the specified kernel image (or from
68 the default image).
69 .Pp
70 The options are as follows:
71 .Bl -tag -width indent
72 .It Fl -libxo
73 Generate output via
74 .Xr libxo 3
75 in a selection of different human and machine readable formats.
76 See
77 .Xr xo_parse_args 3
78 for details on command line arguments.
79 .It Fl a
80 When used with
81 .Fl i ,
82 include statistics about interrupts that have never been generated.
83 .It Fl c
84 Repeat the display
85 .Ar count
86 times.
87 The first display is for the time since a reboot and each subsequent
88 report is for the time period since the last display.
89 If no repeat
90 .Ar count
91 is specified, and
92 .Fl w
93 is specified, the default is infinity, otherwise the default is one.
94 .It Fl f
95 Report on the number
96 .Xr fork 2 ,
97 .Xr vfork 2
98 and
99 .Xr rfork 2
100 system calls since system startup, and the number of pages of virtual memory
101 involved in each.
102 .It Fl h
103 Changes memory columns into more easily human readable form.
104 The default if
105 standard output is a terminal device.
106 .It Fl H
107 Changes memory columns into straight numbers.
108 The default if standard output
109 is not a terminal device (such as a script).
110 .It Fl i
111 Report on the number of interrupts taken by each device since system
112 startup.
113 .It Fl M
114 Extract values associated with the name list from the specified
115 .Ar core .
116 .It Fl N
117 If
118 .Fl M
119 is also specified,
120 extract the name list from the specified
121 .Ar system
122 instead of the default,
123 which is the kernel image the system has booted from.
124 .It Fl m
125 Report on the usage of kernel dynamic memory allocated using
126 .Xr malloc 9
127 by type.
128 .It Fl n
129 Change the maximum number of disks to display from the default of 2.
130 .It Fl o
131 Display a list of virtual memory objects in the system and the resident
132 memory used by each object.
133 .It Fl P
134 Report per-cpu system/user/idle cpu statistics.
135 .It Fl p
136 Specify which types of devices to display.
137 There are three different
138 categories of devices:
139 .Pp
140 .Bl -tag -width indent -compact
141 .It device type:
142 .Bl -tag -width 9n -compact
143 .It da
144 Direct Access devices
145 .It sa
146 Sequential Access devices
147 .It printer
148 Printers
149 .It proc
150 Processor devices
151 .It worm
152 Write Once Read Multiple devices
153 .It cd
154 CD devices
155 .It scanner
156 Scanner devices
157 .It optical
158 Optical Memory devices
159 .It changer
160 Medium Changer devices
161 .It comm
162 Communication devices
163 .It array
164 Storage Array devices
165 .It enclosure
166 Enclosure Services devices
167 .It floppy
168 Floppy devices
169 .El
170 .Pp
171 .It interface:
172 .Bl -tag -width 9n -compact
173 .It IDE
174 Integrated Drive Electronics devices
175 .It SCSI
176 Small Computer System Interface devices
177 .It other
178 Any other device interface
179 .El
180 .Pp
181 .It passthrough:
182 .Bl -tag -width 9n -compact
183 .It pass
184 Passthrough devices
185 .El
186 .El
187 .Pp
188 The user must specify at least one device type, and may specify at most
189 one device type from each category.
190 Multiple device types in a single
191 device type statement must be separated by commas.
192 .Pp
193 Any number of
194 .Fl p
195 arguments may be specified on the command line.
196 All
197 .Fl p
198 arguments are ORed together to form a matching expression against which
199 all devices in the system are compared.
200 Any device that fully matches
201 any
202 .Fl p
203 argument will be included in the
204 .Nm
205 output, up to two devices, or the maximum number of devices specified
206 by the user.
207 .It Fl s
208 Display the contents of the
209 .Em sum
210 structure, giving the total number of several kinds of paging related
211 events which have occurred since system startup.
212 .\" .It Fl t
213 .\" Report on the number of page in and page reclaims since system startup,
214 .\" and the amount of time required by each.
215 .It Fl w
216 Pause
217 .Ar wait
218 seconds between each display.
219 If no repeat
220 .Ar wait
221 interval is specified, the default is 1 second.
222 The
223 .Nm
224 command will accept and honor a non-integer number of seconds.
225 .It Fl z
226 Report on memory used by the kernel zone allocator,
227 .Xr uma 9 ,
228 by zone.
229 .El
230 .Pp
231 The
232 .Ar wait
233 and
234 .Ar count
235 arguments may be given after their respective flags at any point
236 on the command line before the
237 .Ar disks
238 argument(s), or without their flags, as the final argument(s).
239 The latter form is accepted for backwards compatibility, but it is
240 preferred to use the forms with
241 .Fl w
242 and
243 .Fl c
244 to avoid ambiguity.
245 .Pp
246 By default,
247 .Nm
248 displays the following information:
249 .Bl -tag -width indent
250 .It procs
251 Information about the numbers of processes in various states.
252 .Pp
253 .Bl -tag -width indent -compact
254 .It r
255 in run queue
256 .It b
257 blocked for resources (i/o, paging, etc.)
258 .It w
259 runnable or short sleeper (< 20 secs) but swapped
260 .El
261 .It memory
262 Information about the usage of virtual and real memory.
263 Virtual pages (reported in units of 1024 bytes) are considered active if
264 they belong to processes which are running or have run in the last 20
265 seconds.
266 .Pp
267 .Bl -tag -width indent -compact
268 .It avm
269 active virtual pages
270 .It fre
271 size of the free list
272 .El
273 .It page
274 Information about page faults and paging activity.
275 These are averaged each five seconds, and given in units per second.
276 .Pp
277 .Bl -tag -width indent -compact
278 .It flt
279 total number of page faults
280 .It re
281 page reclaims (simulating reference bits)
282 .\" .It at
283 .\" pages attached (found in free list)
284 .It pi
285 pages paged in
286 .It po
287 pages paged out
288 .It fr
289 pages freed per second
290 .\" .It de
291 .\" anticipated short term memory shortfall
292 .It sr
293 pages scanned by clock algorithm, per-second
294 .El
295 .It disks
296 Disk operations per second (this field is system dependent).
297 Typically paging will be split across the available drives.
298 The header of the field is the first two characters of the disk name and
299 the unit number.
300 If more than two disk drives are configured in the system,
301 .Nm
302 displays only the first two drives, unless the user specifies the
303 .Fl n
304 argument to increase the number of drives displayed.
305 This will probably
306 cause the display to exceed 80 columns, however.
307 To force
308 .Nm
309 to display specific drives, their names may be supplied on the command line.
310 The
311 .Nm
312 utility
313 defaults to show disks first, and then various other random devices in the
314 system to add up to two devices, if there are that many devices in the
315 system.
316 If devices are specified on the command line, or if a device type
317 matching pattern is specified (see above),
318 .Nm
319 will only display the given devices or the devices matching the pattern,
320 and will not randomly select other devices in the system.
321 .It faults
322 Trap/interrupt rate averages per second over last 5 seconds.
323 .Pp
324 .Bl -tag -width indent -compact
325 .It in
326 device interrupts per interval (including clock interrupts)
327 .It sy
328 system calls per interval
329 .It cs
330 cpu context switch rate (switches/interval)
331 .El
332 .It cpu
333 Breakdown of percentage usage of CPU time.
334 .Pp
335 .Bl -tag -width indent -compact
336 .It us
337 user time for normal and low priority processes
338 .It sy
339 system time
340 .It id
341 cpu idle
342 .El
343 .El
344 .Sh FILES
345 .Bl -tag -width /boot/kernel/kernel -compact
346 .It Pa /boot/kernel/kernel
347 default kernel namelist
348 .It Pa /dev/kmem
349 default memory file
350 .El
351 .Sh EXAMPLES
352 The command:
353 .Dl vmstat -w 5
354 will print what the system is doing every five
355 seconds; this is a good choice of printing interval since this is how often
356 some of the statistics are sampled in the system.
357 Others vary every second and running the output for a while will make it
358 apparent which are recomputed every second.
359 .Pp
360 The command:
361 .Dl vmstat -p da -p cd -w 1
362 will tell vmstat to select the first two direct access or CDROM devices
363 and display statistics on those devices, as well as other systems
364 statistics every second.
365 .Sh SEE ALSO
366 .Xr fstat 1 ,
367 .Xr netstat 1 ,
368 .Xr nfsstat 1 ,
369 .Xr ps 1 ,
370 .Xr systat 1 ,
371 .Xr libmemstat 3 ,
372 .Xr libxo 3 ,
373 .Xr xo_parse_args 3 ,
374 .Xr gstat 8 ,
375 .Xr iostat 8 ,
376 .Xr pstat 8 ,
377 .Xr sysctl 8 ,
378 .Xr malloc 9 ,
379 .Xr uma 9
380 .Pp
381 The sections starting with ``Interpreting system activity'' in
382 .%T "Installing and Operating 4.3BSD" .
383 .Sh BUGS
384 The
385 .Fl c
386 and
387 .Fl w
388 options are only available with the default output.