uptime查看CPU负载工具
[root@tzPC ~]# uptime 09:21:16 up 4:40, 5 users, load average: 8.13, 5.90, 4.94
第一列:当前时间
第二列up 4:40:系统运行时间,如图已运行了4小时40分钟
5 users:当前用户数
load average:系统负载,显示的是过去的1,5,15分钟内进程队列中的平均进程数量
如何衡量当前系统是否负载过高
如果每个cpu(可以按CPU核心的数量计算)上当前活动进程数不大于3,则系统性能良好,
不大于4,表示可以接受
如大于5,则系统性能问题严重
上面例中的8.13,如果有2个cpu核心,则8.13/2=4.065, 此系统性能可以接受
[root@tzPC ~]# w 09:25:35 up 4:44, 5 users, load average: 0.00, 0.01, 0.05 USER TTY FROM LOGIN@ IDLE JCPU PCPU WHAT root tty1 20Jun20 16:03m 0.03s 0.03s -bash root pts/0 192.168.149.1 20Jun20 21days 0.17s 0.17s -bash root pts/1 192.168.149.1 20Jun20 21days 0.03s 0.03s -bash root pts/2 192.168.149.1 Sat17 14:13m 0.03s 0.00s more root pts/3 192.168.149.1 09:21 7.00s 0.03s 0.02s w
top命令
第一行:
Tasks:95 total 当前总进程数
2 running :正在运行进程数
93 sleeping:
1 stooped:
0 zombie:
第二行:
用户占用CPU的百分比
内核占用CPU的百分比
用户进程空间内改过优先级的进程占用CPU百分比
空闲值CPU百分比,CPU越空闲值越高
CPU等待I/O完成时占用CPU百分比
如果wa占用很多CPU,则表示磁盘性能不足,建议升级磁盘
硬中断
软中断
st偷:虚拟机偷取物理机的CPU的时间。比如linux下安装了KVM虚拟机,KVM虚拟机占用物理机的CPU时间
第三行:
总内存
空闲内存
已使用内存
可被释放内存
第四行:
总交换分区大小
空闲交换分区大小
已使用交换分区大小
可用交换分区大小
第五行
PID
USER
PR:优先级
NI:
VIRT:虚拟内存
RES:实际使用内存
SHR:共享内存
S:状态
占用CPU%
占用内存%
占用CPU时间
命令名
top快捷键
默认3s刷新一次,按s修改刷新时间
空格:立即刷新
q:退出
P:按CPU排序
p:后接进程ID,查看某个进程状态(如top -p 20,动态查看PID为20的进程)
M:按内存排序
T:按时间排序
数字键1:显示每个内核的CPU使用率
u/U:指定显示用户
h:帮助
在linux系统中一个进程可以占用超过100%CPU,如dirtycow(脏牛),提权漏洞
如果是4核心CPU,可以运行400%
lsof命令
查看你进程打开的文件,进程打开的端口
-i <条件>:查找符合条件的进程(如lsof -i :22查看打开22端口的进程)
-p <进程号>:列出指定进程号打开的文件
通过ps -aux | grep xxx找到进程号,再使用lsof -p xxx找到进程访问的文件
pstree工具使用
以树状显示进程,只显示进程的名字,相同进程合并。
-p 显示进程PID
使用此命令需要安装psmisc
yum -y install psmisc