0
点赞
收藏
分享

微信扫一扫

linux下的loadavg

linux下的loadavg真是内容十分丰富,现在加强学习如下: 

1 uptime后,结果的分析如下:

7:51pm up 2 days, 5:43, 2 users,loadaverage: 8.13, 5.90, 4.94


9/84 5662


命令输出的最后内容表示在过去的1、5、15分钟内运行队列中的平均进程数量。

一般来说只要每个CPU的当前活动进程数不大于3那么系统的性能就是良好的,如果每个CPU的任务数大于5,那么就表示这台机器的性能有严重问题。对于上面的例子来说,假设系统有两个CPU,那么其每个CPU的当前任务数为:8.13/2=4.065。这表示该系统的性能是可以接受的。


系统平均负载被定义为在特定时间间隔内运行队列中的平均进程数。如果一个进程满足以下条件则其就会位于运行队列中:

它没有在等待I/O操作的结果

它没有主动进入等待状态(也就是没有调用wait)

没有被停止(例如:等待终止)


最后两列中:

nr_running (9) 在采样时刻,运行队列的任务的数目,与/proc/stat的procs_running表示相同意思 ,即正在运行的进程数

nr_threads (84) 在采样时刻,系统中活跃的任务的个数(不包括运行已经结束的任务)last_pid(5662) 最大的pid值,包括轻量级进程,即线程



2 ps aux结合

运行 ps aux 的到如下信息:

ps aux

USER PID %CPU %MEM VSZ RSS TTY STAT START TIME COMMAND

....................................

stat 中的参数意义如下:

D 不可中断 Uninterruptible(usually IO)

R 正在运行,或在队列中的进程

S 处于休眠状态

T 停止或被追踪

Z 僵尸进程

W 进入内存交换(从内核2.6开始无效)

X 死掉的进程


< 高优先级

n 低优先级

s 包含子进程

+ 位于后台的进程组


使用ps找出这两种状态的进程数

ps aux |awk '{print $8}' |grep ' [D|R] '|wc -l

举报

相关推荐

0 条评论