1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
|
#!/usr/sbin/dtrace -s
/*
* vmstat.d - vmstat demo in DTrace.
* Written using DTrace (Solaris 10 3/05).
*
* This has been written to demonstrate fetching the same data as vmstat
* from DTrace. This program is intended as a starting point for other
* DTrace scripts, by beginning with familiar statistics.
*
* $Id: vmstat.d 8 2007-08-06 05:55:26Z brendan $
*
* USAGE: vmstat.d
*
* FIELDS:
* w swapped out LWPs number
* swap virtual memory free Kbytes
* free free RAM Kbytes
* re page reclaims Kbytes
* mf minor faults Kbytes
* pi page ins Kbytes
* po page outs Kbytes
* fr pages freed Kbytes
* sr scan rate pages
* in interrupts number
* sy system calls number
* cs context switches number
*
* NOTES:
* Most of the statistics are in units of kilobytes, unlike the
* original vmstat command which sometimes uses page counts.
* As this program does not use Kstat, there is no summary since boot line.
* Free RAM is both free free + cache free.
*
* SEE ALSO: vmstat(1M)
*
* COPYRIGHT: Copyright (c) 2005 Brendan Gregg.
*
* CDDL HEADER START
*
* The contents of this file are subject to the terms of the
* Common Development and Distribution License, Version 1.0 only
* (the "License"). You may not use this file except in compliance
* with the License.
*
* You can obtain a copy of the license at Docs/cddl1.txt
* or http://www.opensolaris.org/os/licensing.
* See the License for the specific language governing permissions
* and limitations under the License.
*
* CDDL HEADER END
*
* 11-Jun-2005 Brendan Gregg Created this.
* 08-Jan-2006 " " Last update.
*/
#pragma D option quiet
inline int SCREEN = 21;
/*
* Initialise variables
*/
dtrace:::BEGIN
{
pi = 0; po = 0; re = 0; sr = 0; mf = 0; fr = 0;
sy = 0; in = 0; cs = 0;
lines = SCREEN + 1;
}
/*
* Print header
*/
dtrace:::BEGIN,
profile:::tick-1sec
/lines++ > SCREEN/
{
printf(" %1s %10s %8s %5s %5s %4s %4s %4s %4s %5s %6s %4s\n",
"w", "swap", "free", "re", "mf", "pi", "po", "fr", "sr",
"in", "sy", "cs");
lines = 0;
}
/*
* Probe events
*/
vminfo:::pgpgin { pi += arg0; }
vminfo:::pgpgout { po += arg0; }
vminfo:::pgrec { re += arg0; }
vminfo:::scan { sr += arg0; }
vminfo:::as_fault { mf += arg0; }
vminfo:::dfree { fr += arg0; }
syscall:::entry { sy++; }
sdt:::interrupt-start { in++; }
sched::resume:on-cpu { cs++; }
/*
* Print output line
*/
profile:::tick-1sec
{
/* fetch free mem */
this->free = `freemem;
/*
* fetch free swap
*
* free swap is described in /usr/include/vm/anon.h as,
* MAX(ani_max - ani_resv, 0) + (availrmem - swapfs_minfree)
*/
this->ani_max = `k_anoninfo.ani_max;
this->ani_resv = `k_anoninfo.ani_phys_resv + `k_anoninfo.ani_mem_resv;
this->swap = (this->ani_max - this->ani_resv > 0 ?
this->ani_max - this->ani_resv : 0) + `availrmem - `swapfs_minfree;
/* fetch w */
this->w = `nswapped;
/* convert to Kbytes */
pi *= `_pagesize / 1024;
po *= `_pagesize / 1024;
re *= `_pagesize / 1024;
sr *= `_pagesize / 1024;
mf *= `_pagesize / 1024;
fr *= `_pagesize / 1024;
this->swap *= `_pagesize / 1024;
this->free *= `_pagesize / 1024;
/* print line */
printf(" %1d %10d %8d %5d %5d %4d %4d %4d %4d %5d %6d %4d\n",
this->w, this->swap, this->free, re, mf, pi, po, fr, sr,
in, sy, cs);
/* clear counters */
pi = 0; po = 0; re = 0; sr = 0; mf = 0; fr = 0;
sy = 0; in = 0; cs = 0;
}
|