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

◇◆丶佛笑我妖孽 提交于 2020-04-11 17:25:50
        我们都了解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的体系结构)
易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!