gpt4 book ai didi

Linux:/proc/[pid]/stat 中的开始时间字段在地球上使用 HZ(jiffies) 或 USER_HZ(_SC_CLK_TCK)

转载 作者:塔克拉玛干 更新时间:2023-11-03 01:00:37 25 4
gpt4 key购买 nike

我不想在 Linux 上测量此进程之外的进程的执行持续时间。我发现/proc/[pid]/state 有一个名为 starttime 的字段,在手册页上被描述为“系统启动后进程启动的 jiffies 时间”。

此外,我发现/proc/uptime 提供自系统启动以来耗时 ET(以秒为单位)。从理论上讲,我可以通过以下方式从这两个文件中获取运行时间运行时间 = ET - 开始时间/(每秒 jiffies)。

至于 jiffies,我认为它指的是内核的 CONFIG_HZ(在 ubuntu 12.04 上为 250)而不是 USER_HZ(在 ubuntu 12.04 上为 100,由“getconf CLK_TCK”获取),如 http://www.makelinux.net/books/lkd2/ch10lev1sec3 中所述。 .但是,我对其进行了测试,发现实际上启动时间在ubuntu 12.04上使用的是USER_HZ。我对这一点感到困惑。有人可以向我解释一下吗?非常感谢!

最佳答案

您的 man 页面在您检索时可能已经过时。这是一个 more current page声明如下:

(22) starttime %llu

      The time the process started after system boot.  In
kernels before Linux 2.6, this value was expressed
in jiffies. Since Linux 2.6, the value is expressed
in clock ticks (divide by sysconf(_SC_CLK_TCK)).

在较旧的内核中(Linux 2.6 之前),时间实际上以内核 jiffies 表示。但是,此行为现在更改为以时钟滴答形式提供时间——如您所料通过 USER_HZ 常量缩放的 jiffies。

关于Linux:/proc/[pid]/stat 中的开始时间字段在地球上使用 HZ(jiffies) 或 USER_HZ(_SC_CLK_TCK),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/20584891/

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