- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我一直在尝试分析 perf sched record
的输出但我不明白我用什么引用系来理解“20624.983302 秒”。现在肯定不是 Unix 时间,那是什么?我将如何将其转换为 Unix 时间?
*A0 20624.983302 secs A0 => migration/0:12
*. 20624.983311 secs . => swapper:0
*B0 20624.983318 secs B0 => IPC I/O Child:33924
*. 20624.983355 secs
*C0 20624.983485 secs C0 => WRScene~lder#15:39974
*. 20624.983581 secs
*D0 20624.983972 secs D0 => IPC I/O Parent:33780
最佳答案
这些时间戳是使用内核调度程序时钟捕获的,自启动以来以纳秒计。确切的细节取决于为构建特定 Linux 发行版和目标架构而选择的编译时参数。
通常,样本的时间戳大约在记录时捕获。只要内核保持事件状态,同一内核上的时间戳就可以保证单调增加。您显示的样本都是在同一个核心上捕获的,并且核心从第一个样本到最后一个样本都保持事件状态。因此,在这种情况下,无论平台和分布如何,时间戳都保证是单调的。在多个内核上进行分析时,无法保证所有内核上的时钟同步。
全部 perf
工具使用相同的时钟来捕获时间戳,但它们在打印时间戳的方式上可能有所不同,并且可能会发生两个工具从同一示例文件中以不同的方式打印时间戳。这取决于内核版本。
调用 perf_event_open()
时可以指定时钟源通过设置 use_clockid
到 1 并设置 clockid
到 linux/time.h
中定义的时钟源之一,例如 CLOCK_MONOTONIC
. perf record
提供 -k
或 --clockid
选项指定用于捕获时间戳的时钟源。
x86 上的现代发行版通常使用 TSC 作为调度程序时钟的来源(检查 /sys/devices/system/clocksource/clocksource0/current_clocksource
)。因此,如果您使用的是 x86 处理器,则很可能使用配置内核的 TSC 来捕获 TSC 周期的当前值,该值在内部被转换为纳秒。打印时间戳时,它可能会转换为不同的单位。在这种情况下,时间戳以“seconds.microseconds”格式打印。可以在以下位置找到 TSC 在 Intel 处理器上的行为摘要:Can constant non-invariant tsc change frequency across cpu states? .
关于linux - "perf sched record"使用什么时间范围?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/66974440/
我使用 perf sched record 来记录一些东西。 我从 perf sched script 得到了一些context switch 事件 filebench 2646 [000] 211
当我执行 ls/usr/src/linux-headers-4.10.0-38-generic/include/linux/sched 时,我得到以下结果: deadline.h jobctl.h
我已经在 Windows 中使用 python 创建了在后台运行的调度程序的数量。谁能告诉我任何命令来检查 Windows 上运行的调度程序数量以及如何删除它们? 最佳答案 如果您使用sched.sc
我对 mongodb 很陌生。通过以下方式安装后:brew intall mongodb 然后在终端中键入 mongod,错误抛出:kern.sched unavailable。 我使用的是 mac
我最近开始学习 Python,我正在制作的简单应用程序的一部分包括一个在其自己的线程中运行的带有 hh:mm:ss 显示的计时器。 环顾网络,我发现了两种实现方法: 使用 sched.schedule
我正在编写一个需要在两个给定时间之间运行的 python 脚本。我需要使用 sched 模块中的构建,因为此脚本需要能够直接在任何具有 python 2.7 的机器上运行,以减少配置时间。 (所以 C
tl;dr:在 emacs 组织模式议程 View 中,我不明白为什么我的一些待办事项告诉我他们比预定日期多天数,而其他人则没有。 在 emacs 组织模式下,如果我输入 C-c a a我看到了我今天
我一直在尝试分析 perf sched record 的输出但我不明白我用什么引用系来理解“20624.983302 秒”。现在肯定不是 Unix 时间,那是什么?我将如何将其转换为 Unix 时间?
我需要证明,当进程运行时,我删除了这个进程的 ELF 文件,文件系统中的空闲 block 和节点数不会增加,而在我终止进程后,它们会增加。我还需要显示此过程的整个生命周期中的延迟,因此我正在使用 pe
Linux3.2.0 鉴于以下来源: #include #include int main(void) { printf("%i \n", CLONE_PTRACE);
我正在尝试将列表添加到 linux 内核 (2.4.14-18) 的 sched.h 中的任务结构。 我已经添加了成员 list_t waitList 在task_struct中,添加 waitL
我正在我的 Ubuntu 服务器上寻找 ached.h 文件,但我找不到它。在线它说它在 include/linux/sched.h 但我没有包含文件/不知道它在哪里。有人可以在这里指出我正确的方向吗
我想研究如何将线程手动分配给多核计算机上的特定核心。我发现 include/sched.h 定义了一些可以帮助解决此问题的宏和函数(sched_setaffinity 等)。然而,这些函数是外部的,我
在sched.h ,task_struct 有以下 2 个字段:thread_group 和 thread_node。他们保留了列表的第一个元素,但我找不到它们包含哪种类型的变量。 1511 stru
我正在尝试对 Linux 内核的 sched.h 进行一些更改。默认代码有 struct rq *rq ,它是事件运行队列列表,我需要为每个进程 p 迭代运行队列列表 rq 。有什么办法可以做到吗?
我要把linux程序移植到windows中。但我不知道Windows中的sched.h头相当于什么。任何人都可以帮忙吗? 最佳答案 libpthread是 Windows 的 POSIX 线程的实现。
import sched, time s = sched.scheduler(time.time, time.sleep) def do_something(sc): print("Doing
我正在研究 linux 内核。我修改了 sched.c 以指定我自己的调度策略。但是重新编译成我的自定义内核需要 50 多分钟。为什么我必须编译未修改的源代码?有没有办法只编译sched.c? 我键入
我有一个golang代码示例如下(xx.go): package main import "runtime" func main() { c2 := make(chan int) g
我想改变 Linux 内核,以便每次当前 PID 发生变化时——即,切换到一个新进程——执行一些诊断代码(下面有详细解释,如果好奇的话)。我做了一些挖掘,似乎每次调度程序选择一个新进程时,函数 con
我是一名优秀的程序员,十分优秀!