如何通过进程获取到程序运行在哪个cpu核心

这篇具有很好参考价值的文章主要介绍了如何通过进程获取到程序运行在哪个cpu核心。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

1、taskset

如果一个进程使用 taskset 命令明确的被固定(pinned)到 CPU 的特定内核上,你可以使用 taskset 命令找出被固定的 CPU 内核:

# taskset -c 3 top

查看进程所属核心:

#  taskset -c -p 748320
pid 748320 的当前亲和力列表:3

输出显示这个过程被固定在 CPU 内核 3上。

但是,如果你没有明确固定进程到任何 CPU 内核,你会得到类似下面的亲和力列表。

#  taskset -c -p 748277
pid 748277 的当前亲和力列表:0-7

输出表明该进程可能会被安排在从0到7中的任何一个 CPU 内核。在这种情况下,taskset 不能识别该进程当前被分配给哪个 CPU 内核,你应该使用如下所述的方法。

2、ps

#  ps -o pid,psr,comm -p 631968
    PID PSR COMMAND
 631968   0 dockerd
#  ps -o pid,psr,comm -p 631980
    PID PSR COMMAND
 631980   1 containerd

ps 命令可以告诉你每个进程/线程目前分配到的 (在“PSR”列)CPU ID。
输出表示进程的 PID 为 631968(名为”dockerd”)目前在CPU 内核 0 上运行着。
如果该过程没有被固定,PSR 列会根据内核可能调度该进程到不同内核而改变显示。文章来源地址https://www.toymoban.com/news/detail-707607.html

3、top

top 命令也可以显示 CPU 被分配给哪个进程。首先,在top 命令中使用“P”选项。然后按“f”键,显示中会出现 “Last used CPU” 列。目前使用的 CPU 内核将出现在 “P”(或“PSR”)列下。
top - 17:10:10 up 57 days,  6:00,  3 users,  load average: 0.06, 0.03, 0.00
Tasks: 160 total,   1 running, 159 sleeping,   0 stopped,   0 zombie
%Cpu(s):  0.1 us,  0.0 sy,  0.0 ni, 99.8 id,  0.0 wa,  0.0 hi,  0.0 si,  0.0 st
MiB Mem :  16277.2 total,   1644.8 free,    642.4 used,  13990.1 buff/cache
MiB Swap:      0.0 total,      0.0 free,      0.0 used.  12545.7 avail Mem 

    PID USER      PR  NI    VIRT    RES    SHR S  %CPU  %MEM     TIME+ COMMAND                       P 
      1 root      20   0  175552  17920   8832 S   0.0   0.1   3:02.32 systemd                       5 
      2 root      20   0       0      0      0 S   0.0   0.0   0:00.64 kthreadd                      5 
      3 root       0 -20       0      0      0 I   0.0   0.0   0:00.00 rcu_gp                        0 
      4 root       0 -20       0      0      0 I   0.0   0.0   0:00.00 rcu_par_gp                    0 
      6 root       0 -20       0      0      0 I   0.0   0.0   0:00.00 kworker/0:0H-kblockd          0 
      8 root       0 -20       0      0      0 I   0.0   0.0   0:00.00 mm_percpu_wq                  0 
      9 root      20   0       0      0      0 S   0.0   0.0   0:00.91 ksoftirqd/0                   0 
     10 root      20   0       0      0      0 I   0.0   0.0   9:44.30 rcu_sched                     3 
     11 root      20   0       0      0      0 I   0.0   0.0   0:00.00 rcu_bh                        0 
     12 root      rt   0       0      0      0 S   0.0   0.0   0:02.48 migration/0                   0 
     13 root      20   0       0      0      0 S   0.0   0.0   0:00.00 cpuhp/0                       0 
     14 root      20   0       0      0      0 S   0.0   0.0   0:00.00 cpuhp/1                       1 
     15 root      rt   0       0      0      0 S   0.0   0.0   0:02.03 migration/1                   1 
     16 root      20   0       0      0      0 S   0.0   0.0   0:00.59 ksoftirqd/1                   1 
     18 root       0 -20       0      0      0 I   0.0   0.0   0:00.00 kworker/1:0H-kblockd          1 
     19 root      20   0       0      0      0 S   0.0   0.0   0:00.00 cpuhp/2                       2 
     20 root      rt   0       0      0      0 S   0.0   0.0   0:02.31 migration/2                   2 
     21 root      20   0       0      0      0 S   0.0   0.0   0:00.49 ksoftirqd/2                   2 
     23 root       0 -20       0      0      0 I   0.0   0.0   0:00.00 kworker/2:0H-kblockd  

到了这里,关于如何通过进程获取到程序运行在哪个cpu核心的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 1 java获取cpu核心数目

    2024年02月11日
    浏览(27)
  • linux ubuntu 获取CPU核心数方法 make -j自动制定cpu数量

    nproc是一个可执行程序,直接返回CPU核心数量 yeqiang@yeqiang-MS-7B23:~/Desktop$ /usr/bin/nproc  6   lscpu列出了CPU信息,徐亚配合grep获取核心储量 yeqiang@yeqiang-MS-7B23:~/Desktop$ lscpu 架构:                   x86_64   CPU 运行模式:         32-bit, 64-bit   Address sizes:         39 bits physical,

    2024年03月10日
    浏览(55)
  • 在linux中查看运行指定进程资源占用(cpu+gpu)

    在运行程序时有时候会需要查看资源占用,以方便部署在其他服务器上时进行参考。以下是总结了我在linux上查找程序进程资源的两种方法(cpu和gpu都有)。 如果进程较多,输入 ps -ef | grep + 指令 进行搜索。如果运行的是python程序,可以输入 ps -ef | grep python3 比如我想

    2024年02月04日
    浏览(41)
  • java获取当前服务器状态cpu、内存、存储等核心信息

    目录 1.需要导入依赖包  2.系统自带参数 3.获取当前服务器状态cpu、内存、存储等核心信息  4.引入包后方法不存在  5. 获取的cpu利用率和任务管理器cpu利用率值差距问题   RESULT: RESULT:  需要引入下面的包:  就是需要配置在 CentralProcessor 实例化之前:配置上也会有差距,相

    2024年02月03日
    浏览(34)
  • Java 使用oshi获取当前服务器状态cpu、内存、存储等核心信息

    OSHI 是基于 JNA 的(本地)操作系统和硬件信息库。它不需要安装任何其他额外的本地库,旨在提供一种跨平台的实现来检索系统信息,例如操作系统版本、进程、内存和 CPU 使用率、磁盘和分区、设备、传感器等。 使用 OSHI 可以对应用程序进行监控,可以对应用程序所在的服

    2024年02月03日
    浏览(36)
  • 如何让进程或线程独占CPU核

    核孤立和绑定是一种有效的性能优化手段,能够有效降低关键线程或进程时延,提升运行稳定性。本文前两节描述如何尽量将其他用户或内核线程隔离在指定核心之外,第三节介绍如何将时延敏感进程绑定到指定隔离好的孤立核心上。 1.1 使用tuned实现核孤立 redhat官方推荐使

    2024年02月01日
    浏览(26)
  • Linux如何查看当前占用CPU和内存最多的进程

    查看占用 CPU 最高的前10个进程 查看占用内存(MEM)最高的前10个进程 输入 top 命令,然后按下大写M按照内存MEM排序,按下大写P按照CPU排序

    2024年02月17日
    浏览(37)
  • 如何通过CAD图中的坐标来确定是哪个坐标系

    坐标系分为以下两种: 地理坐标系(Geographic Coordinate System, GCS) 投影坐标系(Projected Coordinate System, PCS) 地理坐标系:为球面坐标。 参考平面地是椭球面,坐标单位:经纬度。 以地球参考为例,坐标系就相当于整个地球,而地理坐标系就是椭球状的完整的立体地球。所以我

    2024年02月07日
    浏览(32)
  • 【看表情包学Linux】进程等待 | wait/waitpid 的 status 参数 | 获取退出码与退出信号 | 初识核心转储

       🤣  爆笑 教程  👉 《看表情包学Linux》👈   猛戳订阅     🔥 💭 写在前面: 在上一章中我们讲解了进程创建与进程终止,本章我们开始讲解进程等待。进程等待这部分知识相较于前面还是较为复杂的,我会由浅入深地讲解这部分的知识点,值得一提的是在学习本章

    2024年02月02日
    浏览(31)
  • 可测含多进程的app-- python调用adb命令获取Android App应用的性能数据:CPU、GPU、内存、电池、耗电量(含python源码)

    python脚本通过os.popen()方法运行adb命令,获取性能数据,将性能数据保存在csv文件并算出均值、最大值、最小值。 本脚本可测试一个app包含多个进程的场景,可以获取 每个进程的性能数据 。 2.1 软件环境 具备python环境,Android环境 需要python库:os, csv, time, datetime, sys,time,panda

    2024年02月13日
    浏览(31)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包