﻿<?xml version="1.0" encoding="utf-8" standalone="yes"?><rss version="2.0" xmlns:dc="http://purl.org/dc/elements/1.1/" xmlns:trackback="http://madskills.com/public/xml/rss/module/trackback/" xmlns:wfw="http://wellformedweb.org/CommentAPI/" xmlns:slash="http://purl.org/rss/1.0/modules/slash/"><channel><title>C++博客-&amp;豪-文章分类-apache</title><link>http://www.cppblog.com/qywyh/category/8148.html</link><description>豪-&gt;blog</description><language>zh-cn</language><lastBuildDate>Tue, 02 Sep 2008 11:00:58 GMT</lastBuildDate><pubDate>Tue, 02 Sep 2008 11:00:58 GMT</pubDate><ttl>60</ttl><item><title>【转】Apache的prefork模式和worker模式</title><link>http://www.cppblog.com/qywyh/articles/60728.html</link><dc:creator>豪</dc:creator><author>豪</author><pubDate>Tue, 02 Sep 2008 10:19:00 GMT</pubDate><guid>http://www.cppblog.com/qywyh/articles/60728.html</guid><wfw:comment>http://www.cppblog.com/qywyh/comments/60728.html</wfw:comment><comments>http://www.cppblog.com/qywyh/articles/60728.html#Feedback</comments><slash:comments>0</slash:comments><wfw:commentRss>http://www.cppblog.com/qywyh/comments/commentRss/60728.html</wfw:commentRss><trackback:ping>http://www.cppblog.com/qywyh/services/trackbacks/60728.html</trackback:ping><description><![CDATA[<h2 class=post-title><a title=Apache的prefork模式和worker模式 href="http://www.ccvita.com/339.html"><font color=#800080><u>Apache的prefork模式和worker模式</u></font></a></h2>
<div class=entry twffan="done">
<p><strong><a href="http://www.ccvita.com/documentation/apache/mod/prefork.html"><u><font color=#0000ff>prefork</font></u></a>模式</strong><br>这个多路处理模块(MPM)实现了一个非线程型的、预派生的web服务器，它的工作方式类似于Apache 1.3。它适合于没有线程安全库，需要避免线程兼容性问题的系统。它是要求将每个请求相互独立的情况下最好的MPM，这样若一个请求出现问题就不会影响到其他请求。</p>
<p>这个MPM具有很强的自我调节能力，只需要很少的配置指令调整。最重要的是将MaxClients设置为一个足够大的数值以处理潜在的请求高峰，同时又不能太大，以致需要使用的内存超出物理内存的大小。</p>
<p><strong><a href="http://www.ccvita.com/documentation/apache/mod/worker.html"><u><font color=#0000ff>worker</font></u></a>模式</strong><br>此多路处理模块(MPM)使网络服务器支持混合的多线程多进程。由于使用线程来处理请求，所以可以处理海量请求，而系统资源的开销小于基于进程的MPM。但是，它也使用了多进程，每个进程又有多个线程，以获得基于进程的MPM的稳定性。</p>
<p>控制这个MPM的最重要的指令是，控制每个子进程允许建立的线程数的ThreadsPerChild指令，和控制允许建立的总线程数的MaxClients指令。</p>
<p><span id=more-339 twffan="done"></span></p>
<p><strong>prefork和worker模式的切换</strong><br>1.将当前的prefork模式启动文件改名<br><span style="WIDTH: 480px; BACKGROUND-COLOR: #cccccc" twffan="done">mv httpd httpd.prefork</span><br>2.将worker模式的启动文件改名<br><span style="WIDTH: 480px; BACKGROUND-COLOR: #cccccc" twffan="done">mv httpd.worker httpd</span><br>3.修改Apache配置文件<br><span style="WIDTH: 480px; BACKGROUND-COLOR: #cccccc" twffan="done">vi /usr/local/apache2/conf/extra/httpd-mpm.conf</span><br>找到里边的如下一段，可适当修改负载等参数：<br><span style="WIDTH: 480px; BACKGROUND-COLOR: #cccccc" twffan="done">&lt;IfModule mpm_worker_module&gt;</span><br><span style="WIDTH: 480px; BACKGROUND-COLOR: #cccccc" twffan="done">StartServers 2</span><br><span style="WIDTH: 480px; BACKGROUND-COLOR: #cccccc" twffan="done">MaxClients 150</span><br><span style="WIDTH: 480px; BACKGROUND-COLOR: #cccccc" twffan="done">MinSpareThreads 25</span><br><span style="WIDTH: 480px; BACKGROUND-COLOR: #cccccc" twffan="done">MaxSpareThreads 75</span><br><span style="WIDTH: 480px; BACKGROUND-COLOR: #cccccc" twffan="done">ThreadsPerChild 25</span><br><span style="WIDTH: 480px; BACKGROUND-COLOR: #cccccc" twffan="done">MaxRequestsPerChild 0</span><br><span style="WIDTH: 480px; BACKGROUND-COLOR: #cccccc" twffan="done">&lt;/IfModule&gt;</span><br>4.重新启动服务<br><span style="WIDTH: 480px; BACKGROUND-COLOR: #cccccc" twffan="done">/usr/local/apache2/bin/apachectl restart</span><br>即可换成worker方式启动apache2</p>
<p>处于稳定性和安全性考虑，不建议更换apache2的运行方式，使用系统默认prefork即可。另外很多php模块不能工作在worker模式下，例如redhat linux自带的php也不能支持线程安全。所以最好不要切换工作模式。</p>
<p><strong>prefork和worker模式的比较</strong><br>prefork模式使用多个子进程，每个子进程只有一个线程。每个进程在某个确定的时间只能维持一个连接。在大多数平台上，Prefork MPM在效率上要比Worker MPM要高，但是内存使用大得多。prefork的无线程设计在某些情况下将比worker更有优势：它可以使用那些没有处理好线程安全的第三方模块，并且对于那些线程调试困难的平台而言，它也更容易调试一些。</p>
<p>worker模式使用多个子进程，每个子进程有多个线程。每个线程在某个确定的时间只能维持一个连接。通常来说，在一个高流量的HTTP服务器上，Worker MPM是个比较好的选择，因为Worker MPM的内存使用比Prefork MPM要低得多。但worker MPM也由不完善的地方，如果一个线程崩溃，整个进程就会连同其所有线程一起&#8221;死掉&#8221;.由于线程共享内存空间，所以一个程序在运行时必须被系统识别为&#8221;每个线程都是安全的&#8221;。</p>
<p>总的来说，prefork方式速度要稍高于worker，然而它需要的cpu和memory资源也稍多于woker。</p>
<p><strong>prefork模式配置详解</strong><br><span style="WIDTH: 480px; BACKGROUND-COLOR: #cccccc" twffan="done">&lt;IfModule mpm_prefork_module&gt;</span><br><span style="WIDTH: 480px; BACKGROUND-COLOR: #cccccc" twffan="done">ServerLimit 256</span><br><span style="WIDTH: 480px; BACKGROUND-COLOR: #cccccc" twffan="done">StartServers 5</span><br><span style="WIDTH: 480px; BACKGROUND-COLOR: #cccccc" twffan="done">MinSpareServers 5</span><br><span style="WIDTH: 480px; BACKGROUND-COLOR: #cccccc" twffan="done">MaxSpareServers 10</span><br><span style="WIDTH: 480px; BACKGROUND-COLOR: #cccccc" twffan="done">MaxClients 256</span><br><span style="WIDTH: 480px; BACKGROUND-COLOR: #cccccc" twffan="done">MaxRequestsPerChild 0</span><br><span style="WIDTH: 480px; BACKGROUND-COLOR: #cccccc" twffan="done">&lt;/IfModule&gt;</span><br>ServerLimit<br>默认的MaxClient最大是256个线程,如果想设置更大的值，就的加上ServerLimit这个参数。20000是ServerLimit这个参数的最大值。如果需要更大，则必须编译apache,此前都是不需要重新编译Apache。<br>生效前提：必须放在其他指令的前面</p>
<p>StartServers<br>指定服务器启动时建立的子进程数量，prefork默认为5。</p>
<p>MinSpareServers<br>指定空闲子进程的最小数量，默认为5。如果当前空闲子进程数少于MinSpareServers ，那么Apache将以最大每秒一个的速度产生新的子进程。此参数不要设的太大。</p>
<p>MaxSpareServers<br>设置空闲子进程的最大数量，默认为10。如果当前有超过MaxSpareServers数量的空闲子进程，那么父进程将杀死多余的子进程。此参数不要设的太大。如果你将该指令的值设置为比MinSpareServers小，Apache将会自动将其修改成&#8221;MinSpareServers+1&#8243;。</p>
<p>MaxClients<br>限定同一时间客户端最大接入请求的数量(单个进程并发线程数)，默认为256。任何超过MaxClients限制的请求都将进入等候队列,一旦一个链接被释放，队列中的请求将得到服务。要增大这个值，你必须同时增大ServerLimit。</p>
<p>MaxRequestsPerChild<br>每个子进程在其生存期内允许伺服的最大请求数量，默认为10000.到达MaxRequestsPerChild的限制后，子进程将会结束。如果MaxRequestsPerChild为&#8221;0&#8243;，子进程将永远不会结束。将MaxRequestsPerChild设置成非零值有两个好处：<br>1.可以防止(偶然的)内存泄漏无限进行，从而耗尽内存。<br>2.给进程一个有限寿命，从而有助于当服务器负载减轻的时候减少活动进程的数量。</p>
<p><strong>worker模式配置详解</strong><br><span style="WIDTH: 480px; BACKGROUND-COLOR: #cccccc" twffan="done">&lt;IfModule mpm_worker_module&gt;</span><br><span style="WIDTH: 480px; BACKGROUND-COLOR: #cccccc" twffan="done">StartServers 2</span><br><span style="WIDTH: 480px; BACKGROUND-COLOR: #cccccc" twffan="done">MaxClients 150</span><br><span style="WIDTH: 480px; BACKGROUND-COLOR: #cccccc" twffan="done">MinSpareThreads 25</span><br><span style="WIDTH: 480px; BACKGROUND-COLOR: #cccccc" twffan="done">MaxSpareThreads 75</span><br><span style="WIDTH: 480px; BACKGROUND-COLOR: #cccccc" twffan="done">ThreadsPerChild 25</span><br><span style="WIDTH: 480px; BACKGROUND-COLOR: #cccccc" twffan="done">MaxRequestsPerChild 0</span><br><span style="WIDTH: 480px; BACKGROUND-COLOR: #cccccc" twffan="done">&lt;/IfModule&gt;</span></p>
<p>StartServers<br>服务器启动时建立的子进程数，默认值是&#8221;3&#8243;。</p>
<p>MaxClients<br>允许同时伺服的最大接入请求数量(最大线程数量)。任何超过MaxClients限制的请求都将进入等候队列。默认值是&#8221;400&#8243;,16(ServerLimit)乘以25(ThreadsPerChild)的结果。因此要增加MaxClients的时候，你必须同时增加ServerLimit的值。</p>
<p>MinSpareThreads<br>最小空闲线程数,默认值是&#8221;75&#8243;。这个MPM将基于整个服务器监视空闲线程数。如果服务器中总的空闲线程数太少，子进程将产生新的空闲线程。</p>
<p>MaxSpareThreads<br>设置最大空闲线程数。默认值是&#8221;250&#8243;。这个MPM将基于整个服务器监视空闲线程数。如果服务器中总的空闲线程数太多，子进程将杀死多余的空闲线程。MaxSpareThreads的取值范围是有限制的。Apache将按照如下限制自动修正你设置的值：worker要求其大于等于MinSpareThreads加上ThreadsPerChild的和。</p>
<p>ThreadsPerChild<br>每个子进程建立的常驻的执行线程数。默认值是25。子进程在启动时建立这些线程后就不再建立新的线程了。</p>
<p>MaxRequestsPerChild<br>设置每个子进程在其生存期内允许伺服的最大请求数量。到达MaxRequestsPerChild的限制后，子进程将会结束。如果MaxRequestsPerChild为&#8221;0&#8243;，子进程将永远不会结束。将MaxRequestsPerChild设置成非零值有两个好处：<br>1.可以防止(偶然的)内存泄漏无限进行，从而耗尽内存。<br>2.给进程一个有限寿命，从而有助于当服务器负载减轻的时候减少活动进程的数量。<br>注意对于KeepAlive链接，只有第一个请求会被计数。事实上，它改变了每个子进程限制最大链接数量的行为。</p>
</div>
<img src ="http://www.cppblog.com/qywyh/aggbug/60728.html" width = "1" height = "1" /><br><br><div align=right><a style="text-decoration:none;" href="http://www.cppblog.com/qywyh/" target="_blank">豪</a> 2008-09-02 18:19 <a href="http://www.cppblog.com/qywyh/articles/60728.html#Feedback" target="_blank" style="text-decoration:none;">发表评论</a></div>]]></description></item><item><title>【manual】Apache MPM prefork</title><link>http://www.cppblog.com/qywyh/articles/60673.html</link><dc:creator>豪</dc:creator><author>豪</author><pubDate>Tue, 02 Sep 2008 03:27:00 GMT</pubDate><guid>http://www.cppblog.com/qywyh/articles/60673.html</guid><wfw:comment>http://www.cppblog.com/qywyh/comments/60673.html</wfw:comment><comments>http://www.cppblog.com/qywyh/articles/60673.html#Feedback</comments><slash:comments>0</slash:comments><wfw:commentRss>http://www.cppblog.com/qywyh/comments/commentRss/60673.html</wfw:commentRss><trackback:ping>http://www.cppblog.com/qywyh/services/trackbacks/60673.html</trackback:ping><description><![CDATA[<div id=page-content twffan="done">
<div id=preamble twffan="done">
<h1>Apache MPM prefork</h1>
<div class=toplang twffan="done">
<p><span twffan="done">Available Languages: </span><a title=Deutsch href="http://httpd.apache.org/docs/2.0/de/mod/prefork.html" hreflang=de rel=alternate>&nbsp;de&nbsp;</a> | <a title=English href="http://httpd.apache.org/docs/2.0/en/mod/prefork.html">&nbsp;en&nbsp;</a> | <a title="Espa񯬢>&nbsp;es&nbsp;</a> |&#10;<a href=" href="http://httpd.apache.org/docs/2.0/es/mod/prefork.html" hreflang=es rel=alternate .. ja mod prefork.html?>&nbsp;ja&nbsp;</a></p>
</div>
<table class=module>
    <tbody>
        <tr>
            <th><a href="http://httpd.apache.org/docs/2.0/mod/module-dict.html#Description">Description:</a></th>
            <td>Implements a non-threaded, pre-forking web server</td>
        </tr>
        <tr>
            <th><a href="http://httpd.apache.org/docs/2.0/mod/module-dict.html#Status">Status:</a></th>
            <td>MPM</td>
        </tr>
        <tr>
            <th><a href="http://httpd.apache.org/docs/2.0/mod/module-dict.html#ModuleIdentifier">Module?Identifier:</a></th>
            <td>mpm_prefork_module</td>
        </tr>
        <tr>
            <th><a href="http://httpd.apache.org/docs/2.0/mod/module-dict.html#SourceFile">Source?File:</a></th>
            <td>prefork.c</td>
        </tr>
    </tbody>
</table>
<h3>Summary</h3>
<p>This Multi-Processing Module (MPM) implements a non-threaded, pre-forking web server that handles requests in a manner similar to Apache 1.3. It is appropriate for sites that need to avoid threading for compatibility with non-thread-safe libraries. It is also the best MPM for isolating each request, so that a problem with a single request will not affect any other.</p>
<p>This MPM is very self-regulating, so it is rarely necessary to adjust its configuration directives. Most important is that <code class=directive><a href="http://httpd.apache.org/docs/2.0/mod/mpm_common.html#maxclients">MaxClients</a></code> be big enough to handle as many simultaneous requests as you expect to receive, but small enough to assure that there is enough physical RAM for all processes.</p>
</div>
<div id=quickview twffan="done">
<h3 class=directives>Directives</h3>
<ul id=toc>
    <li><img alt="" src="http://httpd.apache.org/docs/2.0/images/right.gif" twffan="done"> <a href="http://httpd.apache.org/docs/2.0/mod/mpm_common.html#acceptmutex">AcceptMutex</a>
    <li><img alt="" src="http://httpd.apache.org/docs/2.0/images/right.gif" twffan="done"> <a href="http://httpd.apache.org/docs/2.0/mod/mpm_common.html#bs2000account">BS2000Account</a>
    <li><img alt="" src="http://httpd.apache.org/docs/2.0/images/right.gif" twffan="done"> <a href="http://httpd.apache.org/docs/2.0/mod/mpm_common.html#coredumpdirectory">CoreDumpDirectory</a>
    <li><img alt="" src="http://httpd.apache.org/docs/2.0/images/right.gif" twffan="done"> <a href="http://httpd.apache.org/docs/2.0/mod/mpm_common.html#enableexceptionhook">EnableExceptionHook</a>
    <li><img alt="" src="http://httpd.apache.org/docs/2.0/images/right.gif" twffan="done"> <a href="http://httpd.apache.org/docs/2.0/mod/mpm_common.html#group">Group</a>
    <li><img alt="" src="http://httpd.apache.org/docs/2.0/images/right.gif" twffan="done"> <a href="http://httpd.apache.org/docs/2.0/mod/mpm_common.html#listen">Listen</a>
    <li><img alt="" src="http://httpd.apache.org/docs/2.0/images/right.gif" twffan="done"> <a href="http://httpd.apache.org/docs/2.0/mod/mpm_common.html#listenbacklog">ListenBacklog</a>
    <li><img alt="" src="http://httpd.apache.org/docs/2.0/images/right.gif" twffan="done"> <a href="http://httpd.apache.org/docs/2.0/mod/mpm_common.html#lockfile">LockFile</a>
    <li><img alt="" src="http://httpd.apache.org/docs/2.0/images/right.gif" twffan="done"> <a href="http://httpd.apache.org/docs/2.0/mod/mpm_common.html#maxclients">MaxClients</a>
    <li><img alt="" src="http://httpd.apache.org/docs/2.0/images/right.gif" twffan="done"> <a href="http://httpd.apache.org/docs/2.0/mod/mpm_common.html#maxmemfree">MaxMemFree</a>
    <li><img alt="" src="http://httpd.apache.org/docs/2.0/images/right.gif" twffan="done"> <a href="http://httpd.apache.org/docs/2.0/mod/mpm_common.html#maxrequestsperchild">MaxRequestsPerChild</a>
    <li><img alt="" src="http://httpd.apache.org/docs/2.0/images/down.gif" twffan="done"> <a href="http://httpd.apache.org/docs/2.0/mod/prefork.html#maxspareservers">MaxSpareServers</a>
    <li><img alt="" src="http://httpd.apache.org/docs/2.0/images/down.gif" twffan="done"> <a href="http://httpd.apache.org/docs/2.0/mod/prefork.html#minspareservers">MinSpareServers</a>
    <li><img alt="" src="http://httpd.apache.org/docs/2.0/images/right.gif" twffan="done"> <a href="http://httpd.apache.org/docs/2.0/mod/mpm_common.html#pidfile">PidFile</a>
    <li><img alt="" src="http://httpd.apache.org/docs/2.0/images/right.gif" twffan="done"> <a href="http://httpd.apache.org/docs/2.0/mod/mpm_common.html#receivebuffersize">ReceiveBufferSize</a>
    <li><img alt="" src="http://httpd.apache.org/docs/2.0/images/right.gif" twffan="done"> <a href="http://httpd.apache.org/docs/2.0/mod/mpm_common.html#scoreboardfile">ScoreBoardFile</a>
    <li><img alt="" src="http://httpd.apache.org/docs/2.0/images/right.gif" twffan="done"> <a href="http://httpd.apache.org/docs/2.0/mod/mpm_common.html#sendbuffersize">SendBufferSize</a>
    <li><img alt="" src="http://httpd.apache.org/docs/2.0/images/right.gif" twffan="done"> <a href="http://httpd.apache.org/docs/2.0/mod/mpm_common.html#serverlimit">ServerLimit</a>
    <li><img alt="" src="http://httpd.apache.org/docs/2.0/images/right.gif" twffan="done"> <a href="http://httpd.apache.org/docs/2.0/mod/mpm_common.html#startservers">StartServers</a>
    <li><img alt="" src="http://httpd.apache.org/docs/2.0/images/right.gif" twffan="done"> <a href="http://httpd.apache.org/docs/2.0/mod/mpm_common.html#user">User</a> </li>
</ul>
<h3>Topics</h3>
<ul id=topics>
    <li><img alt="" src="http://httpd.apache.org/docs/2.0/images/down.gif" twffan="done"> <a href="http://httpd.apache.org/docs/2.0/mod/prefork.html#how-it-works">How it Works</a> </li>
</ul>
<h3>See also</h3>
<ul class=seealso>
    <li><a href="http://httpd.apache.org/docs/2.0/bind.html">Setting which addresses and ports Apache uses</a> </li>
</ul>
</div>
<div class=top twffan="done"><a href="http://httpd.apache.org/docs/2.0/mod/prefork.html#page-header"><img alt=top src="http://httpd.apache.org/docs/2.0/images/up.gif" twffan="done"></a></div>
<div class=section twffan="done">
<h2><a id=how-it-works name=how-it-works>How it Works</a></h2>
<p>A single control process is responsible for launching child processes which listen for connections and serve them when they arrive. Apache always tries to maintain several <dfn>spare</dfn> or idle server processes, which stand ready to serve incoming requests. In this way, clients do not need to wait for a new child processes to be forked before their requests can be served.</p>
<p>The <code class=directive><a href="http://httpd.apache.org/docs/2.0/mod/mpm_common.html#startservers">StartServers</a></code>, <code class=directive><a href="http://httpd.apache.org/docs/2.0/mod/prefork.html#minspareservers">MinSpareServers</a></code>, <code class=directive><a href="http://httpd.apache.org/docs/2.0/mod/prefork.html#maxspareservers">MaxSpareServers</a></code>, and <code class=directive><a href="http://httpd.apache.org/docs/2.0/mod/mpm_common.html#maxclients">MaxClients</a></code> regulate how the parent process creates children to serve requests. In general, Apache is very self-regulating, so most sites do not need to adjust these directives from their default values. Sites which need to serve more than 256 simultaneous requests may need to increase <code class=directive><a href="http://httpd.apache.org/docs/2.0/mod/mpm_common.html#maxclients">MaxClients</a></code>, while sites with limited memory may need to decrease <code class=directive><a href="http://httpd.apache.org/docs/2.0/mod/mpm_common.html#maxclients">MaxClients</a></code> to keep the server from thrashing (swapping memory to disk and back). More information about tuning process creation is provided in the <a href="http://httpd.apache.org/docs/2.0/misc/perf-tuning.html">performance hints</a> documentation.</p>
<p>While the parent process is usually started as <code>root</code> under Unix in order to bind to port 80, the child processes are launched by Apache as a less-privileged user. The <code class=directive><a href="http://httpd.apache.org/docs/2.0/mod/mpm_common.html#user">User</a></code> and <code class=directive><a href="http://httpd.apache.org/docs/2.0/mod/mpm_common.html#group">Group</a></code> directives are used to set the privileges of the Apache child processes. The child processes must be able to read all the content that will be served, but should have as few privileges beyond that as possible.</p>
<p><code class=directive><a href="http://httpd.apache.org/docs/2.0/mod/mpm_common.html#maxrequestsperchild">MaxRequestsPerChild</a></code> controls how frequently the server recycles processes by killing old ones and launching new ones.</p>
</div>
<div class=top twffan="done"><a href="http://httpd.apache.org/docs/2.0/mod/prefork.html#page-header"><img alt=top src="http://httpd.apache.org/docs/2.0/images/up.gif" twffan="done"></a></div>
<div class=directive-section twffan="done">
<h2><a id=MaxSpareServers name=MaxSpareServers>MaxSpareServers</a> <a id=maxspareservers name=maxspareservers>Directive</a></h2>
<table class=directive>
    <tbody>
        <tr>
            <th><a href="http://httpd.apache.org/docs/2.0/mod/directive-dict.html#Description">Description:</a></th>
            <td>Maximum number of idle child server processes</td>
        </tr>
        <tr>
            <th><a href="http://httpd.apache.org/docs/2.0/mod/directive-dict.html#Syntax">Syntax:</a></th>
            <td><code>MaxSpareServers <var>number</var></code></td>
        </tr>
        <tr>
            <th><a href="http://httpd.apache.org/docs/2.0/mod/directive-dict.html#Default">Default:</a></th>
            <td><code>MaxSpareServers 10</code></td>
        </tr>
        <tr>
            <th><a href="http://httpd.apache.org/docs/2.0/mod/directive-dict.html#Context">Context:</a></th>
            <td>server config</td>
        </tr>
        <tr>
            <th><a href="http://httpd.apache.org/docs/2.0/mod/directive-dict.html#Status">Status:</a></th>
            <td>MPM</td>
        </tr>
        <tr>
            <th><a href="http://httpd.apache.org/docs/2.0/mod/directive-dict.html#Module">Module:</a></th>
            <td>prefork</td>
        </tr>
    </tbody>
</table>
<p>The <code class=directive>MaxSpareServers</code> directive sets the desired maximum number of <em>idle</em> child server processes. An idle process is one which is not handling a request. If there are more than <code class=directive>MaxSpareServers</code> idle, then the parent process will kill off the excess processes.</p>
<p>Tuning of this parameter should only be necessary on very busy sites. Setting this parameter to a large number is almost always a bad idea. If you are trying to set the value lower than <code class=directive><a href="http://httpd.apache.org/docs/2.0/mod/prefork.html#minspareservers">MinSpareServers</a></code>, Apache will automatically adjust it to <code class=directive>MinSpareServers</code><code> + 1</code>.</p>
<h3>See also</h3>
<ul>
    <li><code class=directive><a href="http://httpd.apache.org/docs/2.0/mod/prefork.html#minspareservers">MinSpareServers</a></code>
    <li><code class=directive><a href="http://httpd.apache.org/docs/2.0/mod/mpm_common.html#startservers">StartServers</a></code> </li>
</ul>
</div>
<div class=top twffan="done"><a href="http://httpd.apache.org/docs/2.0/mod/prefork.html#page-header"><img alt=top src="http://httpd.apache.org/docs/2.0/images/up.gif" twffan="done"></a></div>
<div class=directive-section twffan="done">
<h2><a id=MinSpareServers name=MinSpareServers>MinSpareServers</a> <a id=minspareservers name=minspareservers>Directive</a></h2>
<table class=directive>
    <tbody>
        <tr>
            <th><a href="http://httpd.apache.org/docs/2.0/mod/directive-dict.html#Description">Description:</a></th>
            <td>Minimum number of idle child server processes</td>
        </tr>
        <tr>
            <th><a href="http://httpd.apache.org/docs/2.0/mod/directive-dict.html#Syntax">Syntax:</a></th>
            <td><code>MinSpareServers <var>number</var></code></td>
        </tr>
        <tr>
            <th><a href="http://httpd.apache.org/docs/2.0/mod/directive-dict.html#Default">Default:</a></th>
            <td><code>MinSpareServers 5</code></td>
        </tr>
        <tr>
            <th><a href="http://httpd.apache.org/docs/2.0/mod/directive-dict.html#Context">Context:</a></th>
            <td>server config</td>
        </tr>
        <tr>
            <th><a href="http://httpd.apache.org/docs/2.0/mod/directive-dict.html#Status">Status:</a></th>
            <td>MPM</td>
        </tr>
        <tr>
            <th><a href="http://httpd.apache.org/docs/2.0/mod/directive-dict.html#Module">Module:</a></th>
            <td>prefork</td>
        </tr>
    </tbody>
</table>
<p>The <code class=directive>MinSpareServers</code> directive sets the desired minimum number of <em>idle</em> child server processes. An idle process is one which is not handling a request. If there are fewer than <code class=directive>MinSpareServers</code> idle, then the parent process creates new children at a maximum rate of 1 per second.</p>
<p>Tuning of this parameter should only be necessary on very busy sites. Setting this parameter to a large number is almost always a bad idea.</p>
<h3>See also</h3>
<ul>
    <li><code class=directive><a href="http://httpd.apache.org/docs/2.0/mod/prefork.html#maxspareservers">MaxSpareServers</a></code>
    <li><code class=directive><a href="http://httpd.apache.org/docs/2.0/mod/mpm_common.html#startservers">StartServers</a></code> </li>
</ul>
</div>
</div>
<img src ="http://www.cppblog.com/qywyh/aggbug/60673.html" width = "1" height = "1" /><br><br><div align=right><a style="text-decoration:none;" href="http://www.cppblog.com/qywyh/" target="_blank">豪</a> 2008-09-02 11:27 <a href="http://www.cppblog.com/qywyh/articles/60673.html#Feedback" target="_blank" style="text-decoration:none;">发表评论</a></div>]]></description></item><item><title>【转】apache2.0 prefork和worker模块性能调优</title><link>http://www.cppblog.com/qywyh/articles/60668.html</link><dc:creator>豪</dc:creator><author>豪</author><pubDate>Tue, 02 Sep 2008 03:10:00 GMT</pubDate><guid>http://www.cppblog.com/qywyh/articles/60668.html</guid><wfw:comment>http://www.cppblog.com/qywyh/comments/60668.html</wfw:comment><comments>http://www.cppblog.com/qywyh/articles/60668.html#Feedback</comments><slash:comments>0</slash:comments><wfw:commentRss>http://www.cppblog.com/qywyh/comments/commentRss/60668.html</wfw:commentRss><trackback:ping>http://www.cppblog.com/qywyh/services/trackbacks/60668.html</trackback:ping><description><![CDATA[<strong>[</strong><a href="http://internet.blog.enorth.com.cn/topic/391.shtml"><u><font color=#000000><strong>IT技术</strong></font></u></a><strong>]apache2.0 prefork和worker模块性能调优</strong>
<hr width="100%" noShade SIZE=1>
<table>
    <tbody>
        <tr>
            <td><strong>Tags</strong>: <a href="http://blog.enorth.com.cn/blog/tags/mpm" target=_blank><u><font color=#000000>mpm</font></u></a> <a href="http://blog.enorth.com.cn/blog/tags/apache" target=_blank><u><font color=#000000>apache</font></u></a> </td>
        </tr>
    </tbody>
</table>
<br><span id=zoom twffan="done">
<p>　　Apache 2.0在性能上的改善最吸引人。在支持POSIX线程的Unix系统上，Apache可以通过不同的MPM运行在一种多进程与多线程相混合的模式下，增强部分配置的可扩充性能。相比于Apache 1.3，2.0版本做了大量的优化来提升处理能力和可伸缩性，并且大多数改进在默认状态下即可生效。但是在编译和运行时刻，2.0也有许多可以显著提高性能的选择。本文不想叙述那些以功能换取速度的指令，如HostnameLookups等，而只是说明在2.0中影响性能的最核心特性：MPM（Multi -Processing Modules，多道处理模块）的基本工作原理和配置指令。 </p>
<p>　　毫不夸张地说，MPM的引入是Apache 2.0最重要的变化。大家知道，Apache是基于模块化的设计，而Apache 2.0更扩展了模块化设计到Web服务器的最基本功能。服务器装载了一种多道处理模块，负责绑定本机网络端口、接受请求，并调度子进程来处理请求。扩展模块化设计有两个重要好处： </p>
<p>　　◆ Apache可以更简洁、有效地支持多种操作系统； </p>
<p>　　◆ 服务器可以按站点的特殊需要进行自定制。 </p>
<p>　　在用户级，MPM看起来和其它Apache模块非常类似。主要区别是在任意时刻只能有一种MPM被装载到服务器中。 </p>
<p>　　指定MPM的方法 </p>
<p>　　下面以Red Hat Linux 9为平台，说明在Apache 2.0中如何指定MPM (Apache采用2.0.45)。先解压缩源代码包httpd-2.0.45.tar.gz，生成httpd-2.0.45目录（Apache 1.3源代码包的命名规则是apache_1.3.NN.tar.gz，而2.0版则是httpd-2.0.NN.tar.gz，其中NN是次版本号）。 </p>
<p>　　进入httpd-2.0.45目录，运行以下代码： </p>
<p>$ ./configure --help|grep mpm </p>
<p>&nbsp;</p>
<p>　　显示如下： </p>
<p>--with-mpm=MPM <br>Choose the process model for Apache to use. <br>MPM={beos|worker|prefork|mpmt_os2| perchild|leader|threadpool} </p>
<p>&nbsp;</p>
<p>　　上述操作用来选择要使用的进程模型，即哪种MPM模块。Beos、mpmt_os2分别是BeOS和OS/2上缺省的MPM， perchild主要设计目的是以不同的用户和组的身份来运行不同的子进程。这在运行多个需要CGI的虚拟主机时特别有用，会比1.3版中的SuExec 机制做得更好。leader和threadpool都是基于worker的变体，还处于实验性阶段，某些情况下并不会按照预期设想的那样工作，所以 Apache官方也并不推荐使用。因此，我们主要阐述prefork和worker这两种和性能关系最大的产品级MPM ( 有关其它的MPM详细说明，请参见Apache官方文档：<a href="http://httpd.apache.org/docs-2.0/mod/"><u><font color=#000000>http://httpd.apache.org/docs-2.0/mod/</font></u></a>)。 </p>
<p>　　prefork的工作原理及配置 </p>
<p>　　如果不用&#8220;--with-mpm&#8221;显式指定某种MPM，prefork就是Unix平台上缺省的MPM。它所采用的预派生子进程方式也是 Apache 1.3中采用的模式。prefork本身并没有使用到线程，2.0版使用它是为了与1.3版保持兼容性；另一方面，prefork用单独的子进程来处理不同的请求，进程之间是彼此独立的，这也使其成为最稳定的MPM之一。 </p>
<p>　　若使用prefork，在make编译和make install安装后，使用&#8220;httpd -l&#8221;来确定当前使用的MPM，应该会看到prefork.c（如果看到worker.c说明使用的是worker MPM，依此类推）。再查看缺省生成的httpd.conf配置文件，里面包含如下配置段： </p>
<p>&lt;IfModule prefork.c&gt; <br>StartServers 5 <br>MinSpareServers 5 <br>MaxSpareServers 10 <br>MaxClients 150 <br>MaxRequestsPerChild 0 <br>&lt;/IfModule&gt; </p>
<p>&nbsp;</p>
<p>　　prefork的工作原理是，控制进程在最初建立&#8220;StartServers&#8221;个子进程后，为了满足MinSpareServers设置的需要创建一个进程，等待一秒钟，继续创建两个，再等待一秒钟，继续创建四个&#8230;&#8230;如此按指数级增加创建的进程数，最多达到每秒32个，直到满足 MinSpareServers设置的值为止。这就是预派生（prefork）的由来。这种模式可以不必在请求到来时再产生新的进程，从而减小了系统开销以增加性能。 </p>
<p>　　MaxSpareServers设置了最大的空闲进程数，如果空闲进程数大于这个值，Apache会自动kill掉一些多余进程。这个值不要设得过大，但如果设的值比MinSpareServers小，Apache会自动把其调整为MinSpareServers+1。如果站点负载较大，可考虑同时加大MinSpareServers和MaxSpareServers。 </p>
<p>　　MaxRequestsPerChild设置的是每个子进程可处理的请求数。每个子进程在处理了&#8220;MaxRequestsPerChild&#8221; 个请求后将自动销毁。0意味着无限，即子进程永不销毁。虽然缺省设为0可以使每个子进程处理更多的请求，但如果设成非零值也有两点重要的好处： </p>
<p>　　◆ 可防止意外的内存泄漏； </p>
<p>　　◆ 在服务器负载下降的时侯会自动减少子进程数。 </p>
<p>　　因此，可根据服务器的负载来调整这个值。笔者认为10000左右比较合适。 </p>
<p>　　MaxClients是这些指令中最为重要的一个，设定的是Apache可以同时处理的请求，是对Apache性能影响最大的参数。其缺省值 150是远远不够的，如果请求总数已达到这个值（可通过ps -ef|grep http|wc -l来确认），那么后面的请求就要排队，直到某个已处理请求完毕。这就是系统资源还剩下很多而HTTP访问却很慢的主要原因。系统管理员可以根据硬件配置和负载情况来动态调整这个值。虽然理论上这个值越大，可以处理的请求就越多，但Apache默认的限制不能大于256。如果把这个值设为大于256，那么 Apache将无法起动。事实上，256对于负载稍重的站点也是不够的。在Apache 1.3中，这是个硬限制。如果要加大这个值，必须在&#8220;configure&#8221;前手工修改的源代码树下的src/include/httpd.h中查找 256，就会发现&#8220;#define HARD_SERVER_LIMIT 256&#8221;这行。把256改为要增大的值（如4000），然后重新编译Apache即可。在Apache 2.0中新加入了ServerLimit指令，使得无须重编译Apache就可以加大MaxClients。下面是笔者的prefork配置段： </p>
<p>&lt;IfModule prefork.c&gt; <br>StartServers 10 <br>MinSpareServers 10 <br>MaxSpareServers 15 <br>ServerLimit 2000 <br>MaxClients 1000 <br>MaxRequestsPerChild 10000 <br>&lt;/IfModule&gt; </p>
<p>&nbsp;</p>
<p>　　上述配置中，ServerLimit的最大值是20000，对于大多数站点已经足够。如果一定要再加大这个数值，对位于源代码树下server/mpm/prefork/prefork.c中以下两行做相应修改即可： </p>
<p>#define DEFAULT_SERVER_LIMIT 256 <br>#define MAX_SERVER_LIMIT 20000 </p>
<p>&nbsp;</p>
<p>　　worker的工作原理及配置 </p>
<p>　　相对于prefork，worker是2.0 版中全新的支持多线程和多进程混合模型的MPM。由于使用线程来处理，所以可以处理相对海量的请求，而系统资源的开销要小于基于进程的服务器。但是， worker也使用了多进程，每个进程又生成多个线程，以获得基于进程服务器的稳定性。这种MPM的工作方式将是Apache 2.0的发展趋势。 </p>
<p>　　在configure -with-mpm=worker后，进行make编译、make install安装。在缺省生成的httpd.conf中有以下配置段： </p>
<p>&lt;IfModule worker.c&gt; <br>StartServers 2 <br>MaxClients 150 <br>MinSpareThreads 25 <br>MaxSpareThreads 75 <br>ThreadsPerChild 25 <br>MaxRequestsPerChild 0 <br>&lt;/IfModule&gt; </p>
<p>&nbsp;</p>
<p>　　worker的工作原理是，由主控制进程生成&#8220;StartServers&#8221;个子进程，每个子进程中包含固定的ThreadsPerChild 线程数，各个线程独立地处理请求。同样，为了不在请求到来时再生成线程，MinSpareThreads和MaxSpareThreads设置了最少和最多的空闲线程数；而MaxClients设置了所有子进程中的线程总数。如果现有子进程中的线程总数不能满足负载，控制进程将派生新的子进程。 </p>
<p>　　MinSpareThreads和MaxSpareThreads的最大缺省值分别是75和250。这两个参数对Apache的性能影响并不大，可以按照实际情况相应调节。 </p>
<p>　　ThreadsPerChild是worker MPM中与性能相关最密切的指令。ThreadsPerChild的最大缺省值是64，如果负载较大，64也是不够的。这时要显式使用 ThreadLimit指令，它的最大缺省值是20000。上述两个值位于源码树server/mpm/worker/worker.c中的以下两行： </p>
<p>#define DEFAULT_THREAD_LIMIT 64 <br>#define MAX_THREAD_LIMIT 20000 </p>
<p>&nbsp;</p>
<p>　　这两行对应着ThreadsPerChild和ThreadLimit的限制数。最好在configure之前就把64改成所希望的值。注意，不要把这两个值设得太高，超过系统的处理能力，从而因Apache不起动使系统很不稳定。 </p>
<p>　　Worker模式下所能同时处理的请求总数是由子进程总数乘以ThreadsPerChild值决定的，应该大于等于MaxClients。如果负载很大，现有的子进程数不能满足时，控制进程会派生新的子进程。默认最大的子进程总数是16，加大时也需要显式声明ServerLimit（最大值是20000）。这两个值位于源码树server/mpm/worker/worker.c中的以下两行： </p>
<p>#define DEFAULT_SERVER_LIMIT 16 <br>#define MAX_SERVER_LIMIT 20000 </p>
<p>&nbsp;</p>
<p>　　需要注意的是，如果显式声明了ServerLimit，那么它乘以ThreadsPerChild的值必须大于等于MaxClients，而且MaxClients必须是ThreadsPerChild的整数倍，否则Apache将会自动调节到一个相应值（可能是个非期望值）。下面是笔者的 worker配置段： </p>
<p>&lt;IfModule worker.c&gt; <br>StartServers 3 <br>MaxClients 2000 <br>ServerLimit 25 <br>MinSpareThreads 50 <br>MaxSpareThreads 200 <br>ThreadLimit 200 <br>ThreadsPerChild 100 <br>MaxRequestsPerChild 0 <br>&lt;/IfModule&gt; </p>
<p>&nbsp;</p>
<p>　　通过上面的叙述，可以了解到Apache 2.0中prefork和worker这两个重要MPM的工作原理，并可根据实际情况来配置Apache相关的核心参数，以获得最大的性能和稳定性。 </p>
</span>
<img src ="http://www.cppblog.com/qywyh/aggbug/60668.html" width = "1" height = "1" /><br><br><div align=right><a style="text-decoration:none;" href="http://www.cppblog.com/qywyh/" target="_blank">豪</a> 2008-09-02 11:10 <a href="http://www.cppblog.com/qywyh/articles/60668.html#Feedback" target="_blank" style="text-decoration:none;">发表评论</a></div>]]></description></item></channel></rss>