CPU配置文件位置  /proc/cpuinfo ,CPU性能分析工具:

命令

备注

uname   -a

查看硬件信息

lscpu

查看硬件信息

sar   -u

收集及报告系统当天到目前为止发生的活动信息。默认的输出以十分钟为间隔,显示当天 CPU 的使用情况

vmstat

提供关于系统进程、内存、分页、输入/输出、中断和 CPU 活动的即时报告

top

内存、swap、进程、系统负载

mpstat

硬盘io等待时间、软硬中断时间

pidstat    -u

-r内存、-d磁盘IO

ps   aux

查看CPU使用状态

turbostat

 Intel® 64 位处理器中处理器的拓扑、频率、空闲的电源状态统计、温度和用电量的报告。


 1  uname   -a     

    查看内核名称、主机名、操作系统的内核信息、硬件平台类型、处理器信息以及CPU架构、操作系统类型。

Linux- 分析CPU性能的命令——uname/sar/vmstat/top/mpstat/pidstat/ps/turbostat

参数说明:

-m或–machine 显示主机的硬件(CPU)名

-n或-nodename 显示主机在网络节点上的名称或主机名称

-r或–release 显示linux操作系统内核版本号

-s或–sysname 显示linux内核名称     

-v 显示操作系统是第几个 version 版本

-p 显示处理器类型                   

-i 显示硬件平台类型          

-o 显示操作系统名                   

–version 显示uname版本信息

2  lscpu  

      查看系统CPU架构,CPU型号,逻辑CPU数,核数,处理器数,CPU插槽数,处理器型号,是否支持VT-x,NUMA 节点CPU情况,以及CPU特性等与CPU相关的硬件信息。

Linux- 分析CPU性能的命令——uname/sar/vmstat/top/mpstat/pidstat/ps/turbostat

3  sar   -u        

1)查看操作系统的内核名称、版本(主机名)、当前日期 、架构、以及逻辑CPU个数。

2)查看文件系统读写情况、系统调用的使用情况、磁盘IO、CPU使用率、内存使用率、进程活动。

Linux- 分析CPU性能的命令——uname/sar/vmstat/top/mpstat/pidstat/ps/turbostat

      时间为系统生成报告时间;所统计的CPU数,all是所有CPU;user 用户占用CPU百分比;nice 进程优先级占用CPU百分比;system 系统占用CPU百分比;iowait  IO操作等待所占CPU百分比; steal  管理程序为虚拟进程提供服务而等待CPU所占用百分比;idle  CPU闲置百分比。

4  vmstat

Linux- 分析CPU性能的命令——uname/sar/vmstat/top/mpstat/pidstat/ps/turbostat

说明:

• r,可运行队列的线程数,这些线程都是可运行状态,只不过 CPU 暂时不可用;

• b,被 blocked 的进程数,正在等待 IO 请求;

• in,被处理过的中断数

• cs,系统上正在做上下文切换的数目

• us,用户占用 CPU 的百分比

• sy,内核和中断占用 CPU 的百分比

• wa,所有可运行的线程被 blocked 以后都在等待 IO,这时候 CPU 空闲的百分比

• id,CPU 完全空闲的百分比

5  top

    实时动态地查看系统的整体运行情况,还可以使用top的内置命令交互查看。

Linux- 分析CPU性能的命令——uname/sar/vmstat/top/mpstat/pidstat/ps/turbostat

统计信息:

第1行:Top 任务队列信息(系统运行状态及平均负载),与uptime命令结果相同。

      第1段:系统当前时间,例如:16:07:37

      第2段:系统运行时间,未重启的时间,时间越长系统越稳定。

      格式:up xx days, HH:MM

      例如:241 days, 20:11, 表示连续运行了241天20小时11分钟

第3段:当前登录用户数,例如:1 user,表示当前只有1个用户登录

第4段:系统负载,即任务队列的平均长度,3个数值分别统计最近1,5,15分钟的系统平均负载

系统平均负载:单核CPU情况下,0.00 表示没有任何负荷,1.00表示刚好满负荷,超过1侧表示超负荷,理想值是0.7;

多核CPU负载:CPU核数 * 理想值0.7 = 理想负荷,例如:4核CPU负载不超过2.8何表示没有出现高负载。

第2行:Tasks 进程相关信息

      第1段:进程总数,例如:Tasks: 231 total, 表示总共运行231个进程

第2段:正在运行的进程数,例如:1 running,

第3段:睡眠的进程数,例如:230 sleeping,

第4段:停止的进程数,例如:0 stopped,

第5段:僵尸进程数,例如:0 zombie

第3行:Cpus CPU相关信息,如果是多核CPU,按数字1可显示各核CPU信息,此时1行将转为Cpu核数行,数字1可以来回切换。

第1段:us 用户空间占用CPU百分比,例如:Cpu(s): 12.7%us,

第2段:sy 内核空间占用CPU百分比,例如:8.4%sy,

第3段:ni 用户进程空间内改变过优先级的进程占用CPU百分比,例如:0.0%ni,

第4段:id 空闲CPU百分比,例如:77.1%id,

第5段:wa 等待输入输出的CPU时间百分比,例如:0.0%wa,

第6段:hi CPU服务于硬件中断所耗费的时间总额,例如:0.0%hi,

第7段:si CPU服务软中断所耗费的时间总额,例如:1.8%si,

第8段:st Steal time 虚拟机被hypervisor偷去的CPU时间(如果当前处于一个hypervisor下的vm,实际上hypervisor也是要消耗一部分CPU处理时间的)

第4行:Mem 内存相关信息(Mem: 12196436k total, 12056552k used, 139884k free, 64564k buffers)

第1段:物理内存总量,例如:Mem: 12196436k total,

第2段:使用的物理内存总量,例如:12056552k used,

第3段:空闲内存总量,例如:Mem: 139884k free,

第4段:用作内核缓存的内存量,例如:64564k buffers

第5行:Swap 交换分区相关信息(Swap: 2097144k total, 151016k used, 1946128k free, 3120236k cached)

第1段:交换区总量,例如:Swap: 2097144k total,

第2段:使用的交换区总量,例如:151016k used,

第3段:空闲交换区总量,例如:1946128k free,

第4段:缓冲的交换区总量,3120236k cached

 

进程信息:每5秒刷新一次

      在top命令中按f按可以查看显示的列信息,按对应字母来开启/关闭列,大写字母表示开启,小写字母表示关闭。带*号的是默认列。

A: PID = (Process Id) 进程Id;

E: USER = (User Name) 进程所有者的用户名;

H: PR = (Priority) 优先级

I: NI = (Nice value) nice值。负值表示高优先级,正值表示低优先级

O: VIRT = (Virtual Image (kb)) 进程使用的虚拟内存总量,单位kb。VIRT=SWAP+RES

Q: RES = (Resident size (kb)) 进程使用的、未被换出的物理内存大小,单位kb。RES=CODE+DATA

T: SHR = (Shared Mem size (kb)) 共享内存大小,单位kb

W: S = (Process Status) 进程状态。D=不可中断的睡眠状态,R=运行,S=睡眠,T=跟踪/停止,Z=僵尸进程

K: %CPU = (CPU usage) 上次更新到现在的CPU时间占用百分比

N: %MEM = (Memory usage (RES)) 进程使用的物理内存百分比

M: TIME+ = (CPU Time, hundredths) 进程使用的CPU时间总计,单位1/100秒

 

b: PPID = (Parent Process Pid) 父进程Id

c: RUSER = (Real user name)

d: UID = (User Id) 进程所有者的用户id

f: GROUP = (Group Name) 进程所有者的组名

g: TTY = (Controlling Tty) 启动进程的终端名。不是从终端启动的进程则显示为 ?

j: P = (Last used cpu (SMP)) 最后使用的CPU,仅在多CPU环境下有意义

p: SWAP = (Swapped size (kb)) 进程使用的虚拟内存中,被换出的大小,单位kb

l: TIME = (CPU Time) 进程使用的CPU时间总计,单位秒

r: CODE = (Code size (kb)) 可执行代码占用的物理内存大小,单位kb

s: DATA = (Data+Stack size (kb)) 可执行代码以外的部分(数据段+栈)占用的物理内存大小,单位kb

u: nFLT = (Page Fault count) 页面错误次数

v: nDRT = (Dirty Pages count) 最后一次写入到现在,被修改过的页面数

y: WCHAN = (Sleeping in Function) 若该进程在睡眠,则显示睡眠中的系统函数名

z: Flags = (Task Flags <sched.h>) 任务标志,参考 sched.h

X: COMMAND = (Command name/line) 命令名/命令行

常用交互操作 

基础操作 

1:显示CPU详细信息,每核显示一行

d / s :修改刷新频率,单位为秒

h:可显示帮助界面

n:指定进程列表显示行数,默认为满屏行数

q:退出top

面板隐藏显示 

l:隐藏/显示第1行负载信息;

t:隐藏/显示第2~3行CPU信息;

m:隐藏/显示第4~5行内存信息;

进程列表排序 

M:根据驻留内存大小进行排序;

P:根据CPU使用百分比大小进行排序;

T:根据时间/累计时间进行排序;

     h / ? 可显示帮助界面

6  mpstat

Linux- 分析CPU性能的命令——uname/sar/vmstat/top/mpstat/pidstat/ps/turbostat

irp 硬中断时间 ; soft  软中断时间

7  pidstat   -u

      用于监控全部或指定进程占用系统资源的情况,如CPU,内存、设备IO、任务切换、线程等。pidstat命令指定采样周期和采样次数#pidstat   2   10  ,每2秒输出10次统计信息。

Linux- 分析CPU性能的命令——uname/sar/vmstat/top/mpstat/pidstat/ps/turbostat

8  ps   aux

Linux- 分析CPU性能的命令——uname/sar/vmstat/top/mpstat/pidstat/ps/turbostat

USER: 进程拥有者                        

PID:pid                                      

%CPU:占用的cpu使用率

%MEM:占用的内存使用率               

RSS:占用的虚拟内存大小

TTY:是否为登入者执行的程序,若为tty1-tty6,为本机登入,若为pts/??,为远程登入。

STAT:程序的状态,R:正在执行中,S:睡眠,T:正在检测或者停止,Z:死亡程序

START:程序开始时间                     

IME:程序运行的时间                   

COMMAND:所执行的指令。

查看占用系统CPU最高的5个进程:

Linux- 分析CPU性能的命令——uname/sar/vmstat/top/mpstat/pidstat/ps/turbostat

9  turbostat

Linux- 分析CPU性能的命令——uname/sar/vmstat/top/mpstat/pidstat/ps/turbostat

pkg ——  处理器软件包编号。

core ——  处理器内核编号。

CPU —— LinuxCPU(逻辑处理器)编号。

%c0 ——  cpu 执行完毕的指令间隔百分比。

GHz —— 当 CPU 处于 c0 状态时,平均时钟速度。

TSC —— 整个间隔进程中的平均时钟速度。

%c1、 %c3、和 %c6 —— 处理器分别在 c1、c3 或者 c6 状态下间隔百分比。

%pc3 或者 %pc6 —— 处理器分别在 pc3 或者 pc6 状态下的间隔百分比。

注意:使用 -i 选项指定计数器结果间的不同周期,例如:运行 turbostat -i 10 改为每10秒显示结果。


转载请注明出处,谢谢!

相关文章: