Rumah >Tutorial sistem >LINUX >Cara menggunakan arahan vmstat di bawah Linux
vmstat ialah singkatan daripada virtual memory statistics
Ia adalah alat pemantauan yang sangat berguna di bawah Linux Selain memori, ia juga menyediakan maklumat tambahan seperti blok IO dan masa CPU
vmstat [options] [delay [count]]
mewakili selang kemas kini data dalam saat Jika nilai ini tidak dinyatakan, ia mewakili purata masa sejak sistem bermula, dan hasilnya hanya dikeluarkan sekali pada masa ini.
delay
kiraan
mewakili bilangan output Jika nilai ini tidak dinyatakan, tetapi nilai
.
count
表示输出次数,如果没有指定该值,但是指定了 delay
[root@cghost22 ~]# vmstat procs -----------memory---------- ---swap-- -----io---- -system-- ------cpu----- r b swpd free buff cache si so bi bo in cs us sy id wa st 3 0 0 991324 932 537336 0 0 0 0 3 4 0 0 100 0 0 [root@cghost22 ~]#
vmstat
Terdapat banyak medan dalam keputusan Jadual berikut menyenaraikan penerangan terperinci setiap medan
Lapangan | Arahan |
---|---|
r | Bilangan proses boleh jalan, termasuk keadaan berjalan dan sedia |
b | Bilangan proses dalam keadaan tidur tanpa gangguan |
swpd | Penggunaan memori maya |
percuma | Memori bebas |
buff | Jumlah memori yang digunakan sebagai penimbal |
cache | Jumlah memori yang digunakan sebagai cache |
si | Jumlah memori yang ditukar daripada cakera |
so | Jumlah yang ditukar daripada memori ke cakera |
bi | Blok diterima daripada peranti blok, unit: blok/saat |
bo | Blok dihantar ke peranti blok, unit: blok/saat |
dalam | Bilangan gangguan sesaat, termasuk gangguan jam |
cs | Suis konteks sesaat |
kita | Masa pelaksanaan mod pengguna |
sy | Masa pelaksanaan mod kernel |
id | CPU masa melahu |
wa | Masa menunggu untuk IO |
st | Masa dicuri daripada mesin maya |
Barisan kedua dalam jadual 处于不可中断睡眠状态的进程数量
, uninterruptible di sini merujuk kepada keadaan yang dimasuki proses semasa melaksanakan panggilan sistem tertentu Dalam keadaan ini, proses disekat dan tidak boleh diganggu sehingga panggilan sistem selesai
Hasil medan dibahagikan kepada beberapa bahagian mengikut warna, dari atas ke bawah: maklumat proses, maklumat memori, maklumat IO, gangguan sistem dan konteks, masa CPU
Unit lalai bagi nilai dalam maklumat memori ialah KB (1024 kbait Medan masa CPU tidak mewakili masa tertentu, tetapi peratusan daripada jumlah masa CPU
).Pilihan | Arahan |
---|---|
-a | Tunjukkan ingatan yang aktif dan tidak aktif |
-f | Bilangan garpu sejak sistem dimulakan, termasuk panggilan sistem seperti garpu, vfork dan klon |
-s | Paparkan kiraan acara sistem dan statistik memori |
-d | Laporkan statistik cakera |
-D | Statistik maklumat cakera aktif |
-p | Butiran partition yang ditentukan |
-t | Tambah lajur paparan masa |
-S | Paparan mengikut unit bait yang ditentukan |
-w | Hasil dipaparkan dalam mod lebar |
-V | versi vmstat |
vmstat 命令主要用于识别系统的瓶颈,统计数据的时候,它不会包含自身进程
[root@cghost22 ~]$ vmstat 2 10 procs -----------memory---------- ---swap-- -----io---- -system-- ------cpu----- r b swpd free buff cache si so bi bo in cs us sy id wa st 2 0 12552 148356 234324 3382956 0 0 1 21 4 4 2 2 97 0 0 1 0 12552 148264 234324 3382980 0 0 0 0 14974 27478 3 2 96 0 0 1 0 12552 148232 234324 3382984 0 0 0 14 14384 27181 3 2 96 0 0 0 0 12552 148376 234332 3383052 0 0 0 204 14197 26812 4 2 94 0 0 0 0 12552 148512 234332 3383088 0 0 0 4 14398 27155 3 2 95 0 0 0 0 12552 147892 234332 3383128 0 0 0 210 15515 28802 3 2 95 0 0 1 0 12552 148388 234332 3383156 0 0 0 0 15147 28042 3 2 95 0 0 0 0 12552 148264 234332 3383168 0 0 0 4 14380 27395 3 1 96 0 0 0 0 12552 148264 234336 3383216 0 0 0 198 14430 27008 3 1 95 0 0 2 0 12552 148140 234336 3383252 0 0 0 6 14233 27161 3 2 95 0 0
2
表示每隔 2 秒输出一次结果,10
表示总共输出 10 次,10 次之后程序自动结束
输出的结果中,内存数据的单位默认是 KB,可以通过 -S
选项调整显示的单位,有下面几种单位可供选择
注意:-S
选项对 si、 so
字段无效
k # 1000 bytes K # 1024 bytes m # 1000 * 1000 bytes M # 1024 * 1024 bytes
上图中第一个结果中内存数据显示单位是 KB , 第二个结果中单位是 MB,将第一个结果对应字段的数值除以 1024 就得到了第二个结果
inact
是非活跃内存,active
是活跃内存
活跃内存是进程在使用的内存,非活跃内存是未运行进程的内存
这里的 fork 数量包括 fork、vfork 以及 clone 等系统调用
[root@cghost22 ~]# vmstat -f 12714 forks [root@cghost22 ~]# vmstat -f 12715 forks [root@cghost22 ~]# vmstat -f 12716 forks
我们每次在控制台执行一次命令,系统就会 fork 一个新的进程来执行命令,比如像上面的例子,每执行一次 vmstat -f
命令,系统就会 fork 一个新进程
这个选项还可以用于统计某个操作消耗多少次 fork 调用,只需要在操作前后各执行一次 vmstat -f
命令,比较两次结果的差值即可
追加一列时间显示,有助于比较一段时间内的结果
vmstat 结果中的某些字段的数字有时会比较长,而且跟字段名的位置有偏差, 不太适合人类的观看习惯,-w
选项可以按照宽模式显示数据,使结果看起来更直观,下图是分别未使用宽模式和使用了宽模式的一个对比
磁盘信息主要分三个方面:读、写、IO ,读和写以毫秒为单位,IO以秒为单位
读 total: 成功读取的总数 merged: 分组读取(产生一个 IO) sectors: 成功读取的扇区数 ms: 读取花费的毫秒 写 total: 成功写入的总数 merged: 分组写入(产生一个 IO) sectors: 成功写入的扇区数 ms: 写花费的毫秒 IO cur: 正在进行的IO s: IO花费的秒数
上图中,输出结果显示 sda3 分区设备的信息,它们包括:读计数、读取的扇区数,写计数,分区写请求总数
Atas ialah kandungan terperinci Cara menggunakan arahan vmstat di bawah Linux. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!