帝国网站seo,鲁谷做网站的公司,沈阳市建设工程质量检测中心网站,福田做商城网站建设找哪家公司好判断进程运行在哪个 CPU 内核上
作者#xff1a;Dan Nanni
译者#xff1a;LCTT
| 2015-09-28 10:43
问题#xff1a;Linux 进程运行在多核处理器系统上。怎样才能找出哪个 CPU 内核正在运行该进程#xff1f;
当你在 多核 NUMA 处理器上 运行需要较高性能的 HPC…判断进程运行在哪个 CPU 内核上
作者Dan Nanni
译者LCTT
| 2015-09-28 10:43
问题Linux 进程运行在多核处理器系统上。怎样才能找出哪个 CPU 内核正在运行该进程
当你在 多核 NUMA 处理器上 运行需要较高性能的 HPC高性能计算程序或非常消耗网络资源的程序时CPU/memory 的亲和力是限度其发挥最大性能的重要因素之一。在同一 NUMA 节点上调度最相关的进程可以减少缓慢的远程内存访问。像英特尔 Sandy Bridge 处理器该处理器有一个集成的 PCIe 控制器你可以在同一 NUMA 节点上调度网络 I/O 负载如网卡来突破 PCI 到 CPU 亲和力限制。
作为性能优化和故障排除的一部分你可能想知道特定的进程被调度到哪个 CPU 内核或 NUMA 节点上运行。
这里有几种方法可以找出哪个 CPU 内核被调度来运行给定的 Linux 进程或线程。
方法一 taskset 命令
如果一个进程使用 taskset 命令明确的被固定pinned到 CPU 的特定内核上你可以使用 taskset 命令找出被固定的 CPU 内核
$ taskset -c -p pid例如如果你对 PID 5357 这个进程有兴趣:
$ taskset -c -p 5357
pid 5357s current affinity list: 5输出显示这个过程被固定在 CPU 内核 5 上。
但是如果你没有明确固定进程到任何 CPU 内核你会得到类似下面的亲和力列表。
pid 5357s current affinity list: 0-11输出表明该进程可能会被安排在从 0 到 11 中的任何一个 CPU 内核。在这种情况下taskset 不能识别该进程当前被分配给哪个 CPU 内核你应该使用如下所述的方法。
方法二 ps 命令
ps 命令可以告诉你每个进程 / 线程目前分配到的 在 “PSR” 列CPU ID。
$ ps -o pid,psr,comm -p pidPID PSR COMMAND5357 10 prog输出表示进程的 PID 为 5357名为 “prog”目前在 CPU 内核 10 上运行着。如果该过程没有被固定PSR 列会根据内核可能调度该进程到不同内核而改变显示。
方法三 top 命令
top 命令也可以显示 CPU 被分配给哪个进程。首先在 top 命令中使用 “P” 选项。然后按 “f” 键显示中会出现 “Last used CPU” 列。目前使用的 CPU 内核将出现在 “P”或 “PSR”列下。
$ top -p 5357相比于 ps 命令使用 top 命令的好处是你可以连续监视随着时间的改变 CPU 是如何分配的。
方法四 htop 命令
另一种来检查一个进程 / 线程当前使用的是哪个 CPU 内核的方法是使用 htop 命令。
从命令行启动 htop。按 键进入 “Columns”在 “Available Columns” 下会添加 PROCESSOR。
每个进程当前使用的 CPU ID 将出现在 “CPU” 列中。 请注意所有以前使用的命令 tasksetps 和 top 分配 CPU 内核的 IDs 为 012…N-1。然而htop 分配 CPU 内核 IDs 从 1 开始直到 N。 Linux htop 命令
译者 LCTT runningwater
| 2014-06-03 14:00
在 Linux 系统中top 命令用来显示系统中正在运行的进程的实时状态它显示了一些非常有用的信息比如 CPU 利用情况、内存消耗情况以及每个进程情况等。
还有另外一个命令行工具 htop它与传统的 top 命令功能一样但它有更加强大的功能及能显示更多的信息。这篇文章我们会用实例来讨论这个 htop 命令。
Linux 中的 htop 命令
下面是从 htop 的手册页摘抄下来的相关描述: 它类似于 top 命令但可以让你在垂直和水平方向上滚动所以你可以看到系统上运行的所有进程以及他们完整的命令行。 可以不用输入进程的 PID 就可以对此进程进行相关的操作 (killing, renicing)。 首先明白它的输出
htop 命令以直观的格式来显示信息。下面是 HTOP 的输出快照: htop
如果你观察窗口的左上角部分你会看到显示的是 CPU 负载、内存消耗及交换空间的实时信息右上角包含的是任务、线程、平均负载及系统运行时间的信息。
平均负载部分提供了三个数字这仅仅表示的是过去的 5 分钟、10 分钟和 15 分钟系统的平均负载而已在单核的系统中平均负载为 1 表示的是百分之百的 CPU 利用率。最后运行时间 uptime标示的数字是从系统启动起到当前的运行总时间。
下面我们将用例子来进一步讨论这个命令。
1. 用 F2 键编辑配置
htop 命令提供了许多自定义选项你所要做的就是从主窗口中按下 F2 键。
下面所示的是可用的自定义选项: htop-settings
只需使用箭头键选择和更改特定的设置。
2. 通过 F9 键发送信号
htop 命令可以让你很容易地在 htop 窗口内给一个进程发送任意的信号。按下 F9 键即可。 signals
如你所见窗口的左边部分列出的是所有可用的信号右边部分列出的是进程。只要选中信号并选择一个进程然后按下 enter 键选中的信号就会发送到此进程。
3. 显示进程的树状视图
htop 命令也提供了进程的树状视图查看功能。按下 F5 键切换。
下面是 htop 显示树形视图信息的例子: treeView
要退出树状视图模式请再一次按下 F5 键。
4. 通过 F3 键搜索进程
htop 命令提供了易用的方式来搜索进程。按下 F3 键一个文本框就会出现在窗口底部。
下面是例子: search
如您所见一条名为‘搜索’的文本提示框出现在窗口底部您可以在这儿输入进程的名字然后回车搜索。如果找到它会在列出的进程列表里高亮选中此进程。
5. 通过空格键来设置颜色标注进程条目
在系统中运行着的实时进程视图中要追踪某个进程是个大问题。因为整个列表在不停的刷新着进程的排列顺序也在变动着。为了这个问题 htop 提供了一个很简单的解决方案颜色标注。是的你可以标注一个进程条目它会以不同的颜色显示因此要追踪它就变得容易了。
要标注某个进程条目需要做的就是选中此条目然后按下‘空格’键。例如在下面的截图示例中我已经颜色标注了三个进程条目: color-tag
所以通过此方法你就能很轻松地追踪想查看的进程。
6. 命令行选项
除了上面介绍的一些热键htop 还提供了很有用的命令行选项。下面是其中一部分:
--s 选项: 按指定的列排序。例如htop -s PID命令会按 PID 列的大小排序来显示。 --u 选项: 显示指定的用户的进程信息列表。例如htop -u himanshu命令会只显示出用户名为 himanshu 的相关进程。 --d 选项: 设置刷新的延迟时间。例如htop -d 100命令会使输出在 1 秒后才会刷新参数 -d 的单位是 10 微秒。 via:
http://ask.xmodulo.com/cpu-core-process-is-running.html
作者Dan Nanni 译者strugglingyouth 校对wxy
本文由 LCTT 原创编译Linux 中国. 荣誉推出
http://linoxide.com/linux-command/linux-htop-command/
译者runningwater 校对Caroline