gpt4 book ai didi

monitoring - 返回按区域聚合的 %CPU、%Memory 和网络输入/输出的 Dtrace 脚本

转载 作者:行者123 更新时间:2023-12-04 15:01:09 24 4
gpt4 key购买 nike

我需要一个 DTrace 脚本,它返回 CPU 使用率、内存使用率和网络输入和输出使用的字节数,按区域聚合数据。像这样的东西:

ZONE  %CPU %MEM NET_INPUT NET_OUTPUT
zone1 25% 12% 86012 1294
zone2 48% 65% 86012 7354
zone3 8% 14% 268153 68746

到目前为止,我正在使用:
prstat -Z -c -n 1,99999 5 1

返回类似的东西(没有网络流量):
Please wait...
PID USERNAME SIZE RSS STATE PRI NICE TIME CPU PROCESS/NLWP
32051 root 1090M 1079M sleep 1 0 12:57:25 0,4% qemu-system-x86/7
ZONEID NPROC SWAP RSS MEMORY TIME CPU ZONE
3228 2 1090M 1079M 2,2% 12:57:25 0,4% 6ce064b6-fec9-4daa-ba2b-0082f73fca73
0 105 2075M 633M 1,1% 202:56:51 0,4% global
3031 2 2105M 2094M 4,3% 17:04:52 0,3% e32fb987-35f7-4860-a04a-ca26c327d4ba
(...)
3411 18 81M 54M 0,1% 0:00:04 0,0% 52120eb6-2e20-4a64-8f7a-235a44d9f100
Total: 894 processes, 5460 lwps, load averages: 0,53, 0,53, 0,54

我需要得到相同的结果,但使用 DTrace 完成,以便将数据与网络流量相结合,并在 future 进行更多的探测。

最佳答案

此类脚本尚不存在的原因是使用 DTrace 很难获得 CPU/内存利用率。 DTrace 最适合对特定事件的数据进行采样。要使用 DTrace 获取 CPU 利用率,您需要跟踪 CPU 每次空闲和繁忙时的情况,然后进行一些添加。请注意,这与 DTrace 提供的用于跟踪调度程序操作的提供程序不同,因为这些提供程序基于每个线程而不是每个 CPU。内存更烦人,因为您将跟踪每个内存分配和释放。

要获取这些数据源,从 kstat 中提取数据可能会更好地为您服务。 (听起来您正在使用 Solaris,AFAIK 是唯一具有 kstat 的平台)。可以使用它找到您正在寻找的信息,如下所示:

$ sudo kstat unix:0:system_misc:ncpus      # this is the number of CPUs you have
module: unix instance: 0
name: system_misc class: misc
ncpus 2

$ sudo kstat cpu::sys:cpu_ticks* # ticks of each type for each core since boot
module: cpu instance: 0
name: sys class: misc
cpu_ticks_idle 9375292
cpu_ticks_kernel 82658
cpu_ticks_user 23684
cpu_ticks_wait 0

module: cpu instance: 1
name: sys class: misc
cpu_ticks_idle 9410367
cpu_ticks_kernel 49141
cpu_ticks_user 21956
cpu_ticks_wait 0

$ sudo kstat unix:0:system_pages:physmem # pages of physical memory (multiply by page size for number of bytes)
module: unix instance: 0
name: system_pages class: pages
physmem 1045390

$ sudo kstat unix:0:system_pages:freemem # pages of free memory (multiply by page size for number of bytes)
module: unix instance: 0
name: system_pages class: pages
freemem 880842

请注意,您需要从 CPU 滴答计数器的最后一次读数中减去每个新读数 - 否则,您将跟踪自系统启动以来的滴答总数。当计数器溢出时,它们被设置为 0,然后将新值添加到它们中(这不仅仅是盲目加法溢出)。

您也可以使用 kstat使用 link:0:: 监视通过网络链接读取/写入的字节数.我不确定每个区域是否可以找到此信息,但可能有 kstat这也跟踪。

我想如果您决定使用 DTrace 来监视值,您可以通过跟踪内核中修改这些计数器的时刻并记录修改来强制它这样做。但是,我并没有真正看到这样做的意义,因为使用您已经发现的其他方法更容易。为什么不制作一个脚本来启动两个数据源并将结果组合成更好看的东西?

关于monitoring - 返回按区域聚合的 %CPU、%Memory 和网络输入/输出的 Dtrace 脚本,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/14579255/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com