在使用uptime命令的时候会出现如下:
kingdeAir:~ king$ uptime
21:45 up 1 day, 21:28, 5 users, load averages: 3.01 2.75 2.65
分别表示:
当前时间、系统已经运行了多长时间、目前有多少登陆用户、系统在过去的1分钟、5分钟和15分钟内的平均负载。
那么其中的平均负载是什么意思呢?
平均负载是系统处于可运行状态 和不可中断状态的平均进程数,也就是平均活跃进程数。
可运行状态:正在使用cpu和等待cpu的进程(R状态进程(Running 或Runnable)可使用ps命令查看)
不可中断状态:正处于内核态关键流程中的进程(等待硬件设备的IO响应)
既然平均负载是某段时间内的平均进程活跃数那么岂不就是当有一个CPU的时候只有一个进程的时候才是最理想的状态,当有一个CPU的时候平均负载为2 那么不就意味着 有百分之50的进程抢占不到cpu。
实际操作:
1.查看cpu数量(物理个数):
linux : grep ‘physical id’ /proc/cpuinfo | sort -u
Mac :sysctl hw.physicalcpu
2. 查看最近平均负载
uptime
通过观察最近三代时间的平均负载情况观察其是升高了还是下降了。
4. 使用工具查看平均负载升高的原因
iostat ,mapstat ,pidstat
Mac : brew install stress sysstat
linux : opt install stress sysstat
mpstat 多核cpu性能分析工具,用来试试查看每个cpu的性能指标 以及所有cpu的平均指标
pidstat 是一个仓用的进程性能分析工具,用来查看进程的cpu,内存,i/O以及上下文切换等性能指标
3.具体追踪:
打开新的终端运行mapstat 查看CPU 使用率变化情况
mpstat -p ALL 5(监控所有的CPU,每5秒出一组数据)
4.查看句具体的占用CPU的进程
pidstat -u 5 1 (每5秒出一组数据)
即可看到是具体哪个线程。对其进行优化。