浅谈linux性能调优之十:资源分配规划

        咱们都了解apache的两种工做模式,这节咱们以prefork模式来考虑apache应用的配置!首先说说apache的prefork工做模式:
prefork:特色稳定,对动态页面支持好!
        prefork的工做原理是,控制进程在最初创建"StartServers"个子进程后,为了知足"MinSpareServers"设置的须要建立一 个进程,等待一秒钟,继续建立两个,再等待一秒钟,继续建立四个……如此按指数级增长建立的进程数,最多达到每秒32个,直到知足 MinSpareServers设置的值为止。这就是预派生(prefork)的由来。这种模式能够没必要在请求到来时再产生新的进程,从而减少了系统开销 以增长性能。
        MaxSpareServers设置了最大的空闲进程数,若是空闲进程数大于这个值,apache会自动kill掉一些多余进程。这个值不要设得过大,但 若是设的值比MinSpareServers小,apache会自动把其调整为MinSpareServers+ 1。若是站点负载较大,可考虑同时加大MinSpareServers和MaxSpareServers。
        MaxRequestsPerChild设置的是每一个子进程可处理的请求数。每一个子进程在处理了"MaxRequestsPerChild" 个请求后将自动销毁。0意味着无限,即子进程永不销毁。虽然缺省设为0可使每一个子进程处理更多的请求,但若是设成非零值也有两点重要的好处:
a.可防止意外的内存泄漏;
b.在服务器负载降低的时侯会自动减小子进程数。
        所以,可根据服务器的负载来调整这个值。但也不能过小,否则系统不断的开启新的apache进程,形成资源浪费。
MaxClients 是这些指令中最为重要的一个,设定的是apache能够同时处理的请求,是对apache性能影响最大的参数。其缺省值 150是远远不够的,若是请求总数已达到这个值(可经过ps -ef|grep http|wc -l来确认),那么后面的请求就要排队,直到某个已处理请求完毕。这就是系统资源还剩下不少而http访问却很慢的主要缘由。系统管理员能够根据硬件配置 和负载状况来动态调整这个值。虽然理论上这个值越大,能够处理的请求就越多,但apache默认的限制不能大于256。若是把这个值设为大于256,那么 apache将没法起动。事实上,256对于负载稍重的站点也是不够的。

###################################################################
<IfModule prefork.c>
StartServers       8
MinSpareServers    5
MaxSpareServers   20
ServerLimit      256
MaxClients       256    一个服务器的毫不至于此!
MaxRequestsPerChild  4000
</IfModule>
###################################################################

    看看下面的数据,我使用ab作压力测试:ab -c 500 -t 60 http://127.0.0.1/index.html
    看看一个apache进程占多少内存:
浅谈linux性能调优之十:资源分配规划 - 了了 - OscerSong的博客
 

看看top的man文档:注意这几列
        o: VIRT  --  Virtual Image (kb)
          The  total  amount  of  virtual  memory used by the task.  It includes all
          code, data and shared libraries plus pages that  have  been  swapped  out.
          (Note:  you  can  define  the STATSIZE=1 environment variable and the VIRT
          will be calculated from the /proc/#/state VmSize field.)

          VIRT = SWAP + RES.

       p: SWAP  --  Swapped size (kb)
          The swapped out portion of a task’s total virtual memory image.

       q: RES  --  Resident size (kb)
          The non-swapped physical memory a task has used.

    我的认为:swap可手动添加,而物理内存是主要的限制,能够看出一个httpd占3.3M, MaxClients数量即可以这样计算:
    MaxClients = ( 物理内存*0.8 - 干净开机已使用内存 )/ 3.3M (注意要配置ServerLimit,MaxClients要小于ServerLimit)

    oracle就是一个吃内存的数据库,开启是便分配上G内存给SGA,内部几个重要内存区可手动调整,在规划时,必定要注意系统的安全性与内存的使用率,(不了解的能够看看oracle的体系结构)
相关文章
相关标签/搜索