查看系统配置
-
查看系统版本
lsb_release -a
-
查看内存
-
查看CPU
cat /proc/cpuinfo
-
查看磁盘
查看系统负载
uptime
image.pngtop
top.jpg-
第一行显示的信息分别为:
- 目前的时间
- 开机到目前的时间
- 已经登录的系统用户数
- 系统在1,5,15分钟的平均工作负载
-
第二行显示的信息:
- 目前进程总数,以及各状态的进程数量
-
第三行CPU的整体负载
- %us
- %sy
- %ni
- %id
- %wa
- %hi
- %si
- %st
-
第四行物理内存使用量
-
第五行虚拟内存使用量,交换分区
-
在top执行过程中:可以输入以下命令:
- P 按照CPU使用排序
- M 按照内存资源使用排序
- N 按照PID使用排序
-
top -d 5 界面更新的秒数
-
top -Hp [进程ID] 可以看某个进程的所有线程运行情况
-
top -b -n 2 > text 可以将结果写入文件
-
top -p [PID] 检测指定进程的资源占用
怎么理解平均负载
man uptime
System load averages is the average number of processes that are either in a runnable or uninter‐
ruptable state.
A process in a runnable state is either using the CPU or waiting to use the CPU.
A process in uninterruptable state is waiting for some I/O access, eg waiting for disk.
The averages are taken over the three time intervals.
Load averages are not normalized for the number of CPUs in a system, so a load average of 1 means a single CPU system is loaded all the time while on a 4 CPU system it means it was idle 75% of the time.
平均负载是指单位时间内,系统处于 可运行状态 和 不可中断状态 的平均进程数,也就是平均活跃进程数,它和 CPU 使用率并没有直接关系。
-
可运行状态的进程,是指正在使用 CPU 或者正在等待 CPU 的进程,也就是我们常用 ps 命令看到的,处于 R 状态(Running 或 Runnable)的进程。
-
不可中断状态的进程 则是正处于内核态关键流程中的进程,并且这些流程是不可打断的,比如最常见的是等待硬件设备的 I/O 响应,也就是我们在 ps 命令中看到的 D 状态(Uninterruptible Sleep,也称为 Disk Sleep)的进程。比如,当一个进程向磁盘读写数据时,为了保证数据的一致性,在得到磁盘回复前,它是不能被其他进程或者中断打断的,这个时候的进程就处于不可中断状态。如果此时的进程被打断了,就容易出现磁盘数据与进程数据不一致的问题。
-
平均负载多少合适
平均负载最理想的情况是等于 CPU 个数。
当平均负载高于 CPU 数量 70% 的时候,就应该分析排查负载高的问题了。一旦负载过高,就可能导致进程响应变慢,进而影响服务的正常功能。
测试
在理解了上面的例子后,我们分别测试不同场景下的性能
CPU密集型
第一个终端执行:stress --cpu 1 --timeout 600
第二个终端执行:watch -d uptime
第三个终端执行:mpstat -P ALL 5
那么到底时哪个进程导致了CPU的使用率为100%呢,可以使用pidstat -u 5 1
来查询:
IO密集型
第一个终端执行:stress -i 1 --timeout 600
第二个终端执行:watch -d uptime
第三个终端执行:mpstat -P ALL 5
那么到底时哪个进程导致了CPU的使用率为100%呢,可以使用pidstat -u 5 1
来查询:
大量进程
第一个终端执行:stress -c 4 --timeout 600
第二个终端执行:watch -d uptime
参考资料
网友评论