更新时打印kstat(1秒内多次)

时间:2016-02-15 21:05:58

标签: solaris opensolaris kstat

我正在尝试通过kstat收集统计信息,我目前正在使用dtrace来收集。

这不是基于计数的信息,而是每次都有新数据。

kstat打印的最小间隔是1秒。但是,我需要的数据在一秒钟内改变了几次。每当kstat更新时,有一种方法(API)从kstat获取数据使用dtrace?

1 个答案:

答案 0 :(得分:1)

dtrace之外,无法在更新时获取统计信息,但C libkstat API允许以任意次秒采样率检索kstat统计信息。

如果你想用脚本编写,还有一个perl api

使用它的一种非常简单的方法是创建一个自定义的kstat命令(它恰好是利用kstat perl api的perl脚本)并修改它以使用高分辨率计时器而不是默认计时器,例如:

$ sed '
s/sleep($interval);/Time::HiRes::usleep($interval*1000.);/
/use Sun::Solaris::Kstat/a\
use Time::HiRes;
' /usr/bin/kstat > /var/tmp/kstat_ms
$ chmod +x /var/tmp/kstat_ms
$ /var/tmp/kstat_ms -n lo0 500 3

module: lo                              instance: 0
name:   lo0                             class:    net
        crtime                          19.559031813
        ipackets                        532
        opackets                        532
        snaptime                        4309.506435597


module: lo                              instance: 0
name:   lo0                             class:    net
        crtime                          19.559031813
        ipackets                        534
        opackets                        534
        snaptime                        4310.008578348


module: lo                              instance: 0
name:   lo0                             class:    net
        crtime                          19.559031813
        ipackets                        536
        opackets                        536
        snaptime                        4310.511617682