如何对所有线程进行采样并使用 perf 记录它们的线程 ID?
How do I sample all threads and record their thread id with perf?
我想定期获取有关每个线程正在做什么的信息。不幸的是,我可以在 perf script
输出中看到没有记录线程 ID,因为 -F +tid
的输出看起来与 -F -tid
.
相同
我尝试使用 --per-thread
选项,但它不符合我的要求。相反,它似乎从数据中删除了时间戳字段。
这可能吗?如果不是,perf
报告的多线程程序数据是什么意思——它只是对主线程或随机线程进行采样吗?
事实证明,perf record
已经记录了线程及其 ID。让我感到困惑的是主线程的线程 ID 等于进程 ID。我在进行 -F -tid
测试时也一定是做错了什么,因为线程 ID 的列确实消失了。
我想定期获取有关每个线程正在做什么的信息。不幸的是,我可以在 perf script
输出中看到没有记录线程 ID,因为 -F +tid
的输出看起来与 -F -tid
.
我尝试使用 --per-thread
选项,但它不符合我的要求。相反,它似乎从数据中删除了时间戳字段。
这可能吗?如果不是,perf
报告的多线程程序数据是什么意思——它只是对主线程或随机线程进行采样吗?
事实证明,perf record
已经记录了线程及其 ID。让我感到困惑的是主线程的线程 ID 等于进程 ID。我在进行 -F -tid
测试时也一定是做错了什么,因为线程 ID 的列确实消失了。