Linux系统中Top命令中Load Average的含义(对优化很重要)

top命令中load average显示的是最近1分钟、5分钟和15分钟的系统平均负载。系统平均负载表示

  系统平均负载被定义为在特定时间间隔内运行队列中(在CPU上运行或者等待运行多少进程)的平均进程树。如果一个进程满足以下条件则其就会位于运行队列中:
  - 它没有在等待I/O操作的结果
  - 它没有主动进入等待状态(也就是没有调用’wait’)
  - 没有被停止(例如:等待终止)
  Update:在Linux中,进程分为三种状态,一种是阻塞的进程blocked process,一种是可运行的进程runnable process,另外就是正在运行的进程running process。当进程阻塞时,进程会等待I/O设备的数据或者系统调用。
  进程可运行状态时,它处在一个运行队列run queue中,与其他可运行进程争夺CPU时间。 系统的load是指正在运行running one和准备好运行runnable one的进程的总数。比如现在系统有2个正在运行的进程,3个可运行进程,那么系统的load就是5。load average就是一定时间内的load数量。
标签: 暂无标签
oraunix

写了 199 篇文章,拥有财富 1026,被 339 人关注

转播转播 分享分享 分享淘帖
回复

使用道具

P6 | 发表于 2013-3-13 21:30:11
top命令 会有load average信息。有三个值,分别代表:当前,最新5分钟,最新15分钟的cpu负载。例如:
top - 14:42:45 up 1189 days, 15:29,  6 users,  load average: 0.15, 0.83, 6.08
那cpu负载。又是什么呢?代表当前cpu处理的任务个数。
这个值为多少为好呢?理想状态为:cpu的数量  即双核的cpu这个值在2比较理想。代表当前cpu处理饱和。正常情况应保持在70%左右为好。太小浪费机器,太大会有系统反应慢的情况。
如果数量大于理想数量。则会出现线程等待的情况。代表该机器的cpu已经不够用了。

查看cpu数量方法1.
grep 'model name' /proc/cpuinfo |wc -l
查看cpu数量方法2.
top然后按1. 会显示所有的cpu
回复

使用道具

hzs
P4 | 发表于 2013-3-15 10:40:12
对top 又有了新的认识
收藏收藏
回复

使用道具

P4 | 发表于 2013-8-23 16:21:29
本帖最后由 007xuwanxin 于 2013-8-23 16:22 编辑

相老师,麻烦您了,请教一下
uptime
16:16:28 up 8 days,  8:31,  2 users,  load average: 7.11, 6.89, 6.77


$ cat /proc/cpuinfo |grep "physical id"|sort |uniq|wc -l
4
$ cat /proc/cpuinfo |grep "processor"|wc -l
48
$ cat /proc/cpuinfo |grep "cores"|uniq
cpu cores       : 6
$ cat /proc/cpuinfo |grep MHz|uniq
cpu MHz         : 1064.000
cpu MHz         : 1862.000
cpu MHz         : 1064.000
cpu MHz         : 1862.000
$


网上关于load average的解释五花八门,到底是按physical,还是按cores,还是按processor算?
迁移到新库的性能问题,具体参看下面两个帖子

http://www.jiagulun.com/thread-271657-1-1.html
http://www.jiagulun.com/thread-271578-1-1.html
回复

使用道具

您需要登录后才可以回帖 登录 | 加入社区

本版积分规则

意见
反馈