<p>Dieses Multi-Processing-Modul (MPM) implementiert einen Hybrid-Server
mit Multi-Thread und Multi-Prozess-Unterstⁿtzung. Durch die Verwendung
von Threads fⁿr die Bedienung von Anfragen ist er in der Lage,
eine gro▀e Anzahl von Anfragen mit weniger Systemressourcen als
ein Prozess-basierter Server zu bedienen. Er behΣlt jedoch viel von
der StabilitΣt eines Prozess-basierten Servers bei, indem er
mehrere Prozesse verfⁿgbar hΣlt, jeden mit etlichen Threads.</p>
<p>Die wichtigsten Direktiven zur Steuerung des MPMs sind <code class="directive"><a href="../mod/mpm_common.html#threadsperchild">ThreadsPerChild</a></code>, welche die Anzahl
der Threads beeinflusst, die von jedem Kindprozess verwendet werden, und
<code class="directive"><a href="../mod/mpm_common.html#maxclients">MaxClients</a></code>, welche die
maximale Gesamtzahl an Threads regelt, die gestartet werden
Dann, wΣhrend des Betriebes, berechnet der Apache die Gesamtzahl
der unbeschΣftigten Threads und forkt oder beendet Prozesse, um diese
Anzahl innerhalb der durch <code class="directive"><a href="../mod/mpm_common.html#minsparethreads">MinSpareThreads</a></code> und <code class="directive"><a href="../mod/mpm_common.html#maxsparethreads">MaxSpareThreads</a></code> angegebenen Grenzen
zu halten. Da dieser Prozess sehr selbstregulierend ist, ist es nur selten
notwendig, die Voreinstellung dieser Direktiven zu Σndern. Die
maximale Anzahl Clients, die gleichzeitig bedient werden kann (d.h.
die maximale Gesamtzahl der Threads in allen Prozessen), wird mit der
festgelegt, wΣhrend die maximale Anzahl Prozesse, die gestartet
werden kann, von der Direktive <code class="directive"><a href="../mod/mpm_common.html#serverlimit">ServerLimit</a></code> bestimmt wird. <code class="directive"><a href="../mod/mpm_common.html#serverlimit">ServerLimit</a></code> multipliziert mit <code class="directive"><a href="../mod/mpm_common.html#threadsperchild">ThreadsPerChild</a></code> muss gr÷▀er
oder gleich <code class="directive"><a href="../mod/mpm_common.html#maxclients">MaxClients</a></code>
sein.</p>
<p>Eine typische Konfiguration der Prozess-Thread-Steuerung fⁿr
das MPM <code class="module"><a href="../mod/worker.html">worker</a></code> k÷nnte wie folgt aussehen:</p>
<div class="example"><p><code>
StartServers 2<br />
MaxClients 150<br />
MinSpareThreads 25<br />
MaxSpareThreads 75<br />
ThreadsPerChild 25<br />
ServerLimit 16
</code></p></div>
<p>WΣhrend der Elternprozess unter Unix normalerweise als
<code>root</code> gestartet wird, um sich an Port 80 binden zu k÷nnen,
werden die Kindprozesse und Threads unter einem weniger privilegierten
Benutzer gestartet. Die Direktiven <code class="directive"><a href="../mod/mpm_common.html#user">User</a></code> und <code class="directive"><a href="../mod/mpm_common.html#group">Group</a></code> werden dazu verwendet, die
Privilegien der Apache-Kindprozesse festzulegen. Die Kindprozesse
mⁿssen in der Lage sein, alle Inhalte zu lesen, die sie ausliefern
sollen, sollten darⁿber hinaus jedoch so wenig wie m÷glich Rechte
besitzen. ZusΣtzlich, solange nicht <a href="../suexec.html">suexec</a> verwendet wird, legen diese
Direktiven auch die Privilegien fest, die von CGI-Skripts