日期:2014-05-16  浏览次数:20576 次

Linux服务器性能评估与优化(zz)
from:

一、影响Linux服务器性能的因素

1. 操作系统级

 

?       CPU

?       内存

?       磁盘I/O带宽

?       网络I/O带宽

 

2.        程序应用级



二、系统性能评估标准

影响性能因素
评判标准



糟糕

CPU
user% + sys%< 70%
user% + sys%= 85%
user% + sys% >=90%

内存
Swap In(si)=0

Swap Out(so)=0
Per CPU with 10 page/s
More Swap In & Swap Out

磁盘
iowait % < 20%
iowait % =35%
iowait % >= 50%




 

其中:

       %user:表示CPU处在用户模式下的时间百分比。

       %sys:表示CPU处在系统模式下的时间百分比。

       %iowait:表示CPU等待输入输出完成时间的百分比。

       swap in:即si,表示虚拟内存的页导入,即从SWAP DISK交换到RAM

       swap out:即so,表示虚拟内存的页导出,即从RAM交换到SWAP DISK。



三、系统性能分析工具

 

1.常用系统命令

Vmstat、sar、iostat、netstat、free、ps、top等

 

2.常用组合方式

?           用vmstat、sar、iostat检测是否是CPU瓶颈

?           用free、vmstat检测是否是内存瓶颈

?           用iostat检测是否是磁盘I/O瓶颈

?           用netstat检测是否是网络带宽瓶颈

 

四、Linux性能评估与优化



1. 系统整体性能评估(uptime命令)



[root@web1 ~]# uptime

16:38:00 up 118 days,  3:01,  5 users,  load average: 1.22, 1.02, 0.91

这里需要注意的是:load average这个输出值,这三个值的大小一般不能大于系统CPU的个数,例如,本输出中系统有8个CPU,如果load average的三个值长期大于8时,说明CPU很繁忙,负载很高,可能会影响系统性能,但是偶尔大于8时,倒不用担心,一般不会影响系统性能。相反,如果load average的输出值小于CPU的个数,则表示CPU还有空闲的时间片,比如本例中的输出,CPU是非常空闲的。



2. CPU性能评估



(1)利用vmstat命令监控系统CPU

   该命令可以显示关于系统各种资源之间相关性能的简要信息,这里我们主要用它来看CPU一个负载情况。

   下面是vmstat命令在某个系统的输出结果:

 

[root@node1 ~]# vmstat 2 3

procs -----------memory----------  ---swap--  -----io---- --system--  -----cpu------

r  b   swpd   free      buff  cache   si   so    bi    bo       in     cs     us sy  id   wa st

0  0    0    162240   8304  67032   0    0    13    21   1007   23     0  1   98   0   0

0  0    0    162240   8304  67032   0    0     1     0     1010   20     0  1   100 0   0

0  0    0    162240   8304  67032   0    0     1     1     1009   18     0  1    99  0   0

l        Procs

     r列表示运行和等待cpu时间片的进程数,这个值如果长期大于系统CPU的个数,说明CPU不足,需要增加CPU。

     b列