目录
一:top
二: ps
三:perf
四:/proc/stat
五:pidstat
一:top
使用 top 命令:在终端中输入 top 命令,系统会显示当前正在运行的进程和它们的资源占用情况。默认情况下,top 命令会按照 CPU 使用率对进程进行排序,使用率高的进程会排在前面。你可以通过查看进程列表来确定哪些进程占用了大量的 CPU。
如果想要查看 CPU 使用率的历史数据,可以使用 top 命令的 -b(批处理模式)选项。在批处理模式下,top 命令会以类似于报告的形式输出各个进程的资源占用状况,包括 CPU、内存、进程数等。可以使用以下命令来查看 CPU 使用率的历史数据:
top -b -n 1 > top.txttop -b -n 1 > top.txt
其中,-n 1 表示只输出一次数据,输出的结果会被重定向到 top.txt 文件中。可以通过查看 top.txt 文件来了解 CPU 使用率的历史数据。
二: ps
使用 ps 命令:ps 命令可以用来查看进程的状态和资源占用情况。使用以下命令可以查看当前正在运行的进程的 CPU 使用率:
ps -e -o pid,user,%cpu --sort=-%cpu
这个命令会列出所有进程的 PID、用户名和 CPU 使用率,并按照 CPU 使用率进行降序排序。通过查看进程列表,你可以确定哪些进程占用了大量的 CPU。
-e: 选择所有进程。
-o: 指定输出格式,这里指定了 PID、用户名和 CPU 使用率。
--sort=-%cpu: 按照 CPU 使用率进行排序,- 表示降序排序。
如果你只对某个特定用户的进程感兴趣,可以在命令中添加一个 grep 过滤条件,例如:
ps -eo pid,user,%cpu --sort=-%cpu | grep username
三:perf
使用 perf 工具:perf 是 Linux 内核自带的一个性能分析工具,可以用来分析系统的性能瓶颈。你可以使用 perf 工具来查找占用 CPU 的程序。首先,你需要安装 perf 工具,然后使用以下命令来运行 perf:
perf record -g <command>
其中,<command> 是你想要分析的程序或命令。运行完程序后,使用以下命令来查看 perf 的分析结果:
perf report
这个命令会显示程序的调用栈和 CPU 占用情况,帮助你找到占用 CPU 的程序。
四:/proc/stat
在 Linux 中,可以通过 /proc/stat 文件来查看 CPU 的占用情况。这个文件包含了每个 CPU 的用户态、系统态、空闲态等状态的时间片信息。
要查看 CPU 的占用情况,可以使用以下命令:
cat /proc/stat
个命令会输出一个以空格分隔的列表,其中包含了各个 CPU 状态的时间片信息。
要计算 CPU 的即时利用率,可以使用以下公式:
CPU 利用率 = (CPU 空闲时间 - 初始 CPU 空闲时间) / (当前时间 - 初始时间) * 100%
其中,CPU 空闲时间可以从 /proc/stat 文件中获取,初始 CPU 空闲时间和初始时间需要记录下来。
具体的计算步骤如下:
1 记录下当前时间和初始 CPU 空闲时间。
2 等待一段时间(比如 1 秒),再次记录下当前时间和 CPU 空闲时间。
3 使用以下公式计算 CPU 的利用率:
CPU 利用率 = [(当前 CPU 空闲时间 - 初始 CPU 空闲时间) - (当前时间 - 初始时间)] / (当前时间 - 初始时间) * 100%
4 将计算结果输出即可。
需要注意的是,/proc/stat 文件中的数据是从系统启动开始累计的,因此需要从系统启动时间开始记录初始 CPU 空闲时间和初始时间,并在每个采样点重新记录这些值。另外,这个方法只能计算 CPU 的即时利用率,如果需要计算一段时间内的平均利用率,需要多次采样并取平均值。
五:pidstat
pidstat 是一个用于监视进程活动的工具,它是 sysstat 包的一部分。使用 pidstat 可以查看进程的 CPU、内存、I/O 等资源占用情况。
输入以下命令以查看占用 CPU 最高的进程:
pidstat -p <PID>
将 <PID> 替换为你要监视的进程的进程 ID。如果你想监视所有进程,可以使用 -a 选项。
如果你想监视一段时间内的进程活动,可以使用以下命令:
pidstat -d -p <PID> 1