1 <?xml version="1.0" encoding="ISO-8859-1"?>
2 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
3 <html xmlns="http://www.w3.org/1999/xhtml" lang="de" xml:lang="de"><head><!--
4 XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX
5 This file is generated from xml source: DO NOT EDIT
6 XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX
8 <title>worker - Apache HTTP Server</title>
9 <link href="../style/css/manual.css" rel="stylesheet" media="all" type="text/css" title="Main stylesheet" />
10 <link href="../style/css/manual-loose-100pc.css" rel="alternate stylesheet" media="all" type="text/css" title="No Sidebar - Default font size" />
11 <link href="../style/css/manual-print.css" rel="stylesheet" media="print" type="text/css" />
12 <link href="../images/favicon.ico" rel="shortcut icon" /></head>
14 <div id="page-header">
15 <p class="menu"><a href="../mod/">Module</a> | <a href="../mod/directives.html">Direktiven</a> | <a href="../faq/">FAQ</a> | <a href="../glossary.html">Glossar</a> | <a href="../sitemap.html">Seitenindex</a></p>
16 <p class="apache">Apache HTTP Server Version 2.3</p>
17 <img alt="" src="../images/feather.gif" /></div>
18 <div class="up"><a href="./"><img title="<-" alt="<-" src="../images/left.gif" /></a></div>
20 <a href="http://www.apache.org/">Apache</a> > <a href="http://httpd.apache.org/">HTTP-Server</a> > <a href="http://httpd.apache.org/docs/">Dokumentation</a> > <a href="../">Version 2.3</a> > <a href="./">Module</a></div>
21 <div id="page-content">
22 <div id="preamble"><h1>Apache-MPM worker</h1>
24 <p><span>Verfügbare Sprachen: </span><a href="../de/mod/worker.html" title="Deutsch"> de </a> |
25 <a href="../en/mod/worker.html" hreflang="en" rel="alternate" title="English"> en </a> |
26 <a href="../ja/mod/worker.html" hreflang="ja" rel="alternate" title="Japanese"> ja </a> |
27 <a href="../tr/mod/worker.html" hreflang="tr" rel="alternate" title="Türkçe"> tr </a></p>
29 <div class="outofdate">Diese Übersetzung ist möglicherweise
30 nicht mehr aktuell. Bitte prüfen Sie die englische Version auf
31 die neuesten Änderungen.</div>
32 <table class="module"><tr><th><a href="module-dict.html#Description">Beschreibung:</a></th><td>Multi-Processing-Modul, das einen Hybrid-Webserver mit
33 Multi-Thread und Multi-Prozess-Unterstützung implementiert</td></tr>
34 <tr><th><a href="module-dict.html#Status">Status:</a></th><td>MPM</td></tr>
35 <tr><th><a href="module-dict.html#ModuleIdentifier">Modulbezeichner:</a></th><td>mpm_worker_module</td></tr>
36 <tr><th><a href="module-dict.html#SourceFile">Quelltext-Datei:</a></th><td>worker.c</td></tr></table>
37 <h3>Zusammenfassung</h3>
39 <p>Dieses Multi-Processing-Modul (MPM) implementiert einen Hybrid-Server
40 mit Multi-Thread und Multi-Prozess-Unterstützung. Durch die Verwendung
41 von Threads für die Bedienung von Anfragen ist er in der Lage,
42 eine große Anzahl von Anfragen mit weniger Systemressourcen als
43 ein Prozess-basierter Server zu bedienen. Er behält jedoch viel von
44 der Stabilität eines Prozess-basierten Servers bei, indem er
45 mehrere Prozesse verfügbar hält, jeden mit etlichen Threads.</p>
47 <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
48 der Threads beeinflusst, die von jedem Kindprozess verwendet werden, und
49 <code class="directive"><a href="../mod/mpm_common.html#maxclients">MaxClients</a></code>, welche die
50 maximale Gesamtzahl an Threads regelt, die gestartet werden
53 <div id="quickview"><h3 class="directives">Direktiven</h3>
55 <li><img alt="" src="../images/right.gif" /> <a href="mpm_common.html#acceptmutex">AcceptMutex</a></li>
56 <li><img alt="" src="../images/right.gif" /> <a href="mpm_common.html#coredumpdirectory">CoreDumpDirectory</a></li>
57 <li><img alt="" src="../images/right.gif" /> <a href="mpm_common.html#enableexceptionhook">EnableExceptionHook</a></li>
58 <li><img alt="" src="../images/right.gif" /> <a href="mpm_common.html#group">Group</a></li>
59 <li><img alt="" src="../images/right.gif" /> <a href="mpm_common.html#listen">Listen</a></li>
60 <li><img alt="" src="../images/right.gif" /> <a href="mpm_common.html#listenbacklog">ListenBacklog</a></li>
61 <li><img alt="" src="../images/right.gif" /> <a href="mpm_common.html#lockfile">LockFile</a></li>
62 <li><img alt="" src="../images/right.gif" /> <a href="mpm_common.html#maxclients">MaxClients</a></li>
63 <li><img alt="" src="../images/right.gif" /> <a href="mpm_common.html#maxmemfree">MaxMemFree</a></li>
64 <li><img alt="" src="../images/right.gif" /> <a href="mpm_common.html#maxrequestsperchild">MaxRequestsPerChild</a></li>
65 <li><img alt="" src="../images/right.gif" /> <a href="mpm_common.html#maxsparethreads">MaxSpareThreads</a></li>
66 <li><img alt="" src="../images/right.gif" /> <a href="mpm_common.html#minsparethreads">MinSpareThreads</a></li>
67 <li><img alt="" src="../images/right.gif" /> <a href="mpm_common.html#pidfile">PidFile</a></li>
68 <li><img alt="" src="../images/right.gif" /> <a href="mpm_common.html#receivebuffersize">ReceiveBufferSize</a></li>
69 <li><img alt="" src="../images/right.gif" /> <a href="mpm_common.html#scoreboardfile">ScoreBoardFile</a></li>
70 <li><img alt="" src="../images/right.gif" /> <a href="mpm_common.html#sendbuffersize">SendBufferSize</a></li>
71 <li><img alt="" src="../images/right.gif" /> <a href="mpm_common.html#serverlimit">ServerLimit</a></li>
72 <li><img alt="" src="../images/right.gif" /> <a href="mpm_common.html#startservers">StartServers</a></li>
73 <li><img alt="" src="../images/right.gif" /> <a href="mpm_common.html#threadlimit">ThreadLimit</a></li>
74 <li><img alt="" src="../images/right.gif" /> <a href="mpm_common.html#threadsperchild">ThreadsPerChild</a></li>
75 <li><img alt="" src="../images/right.gif" /> <a href="mpm_common.html#threadstacksize">ThreadStackSize</a></li>
76 <li><img alt="" src="../images/right.gif" /> <a href="mpm_common.html#user">User</a></li>
80 <li><img alt="" src="../images/down.gif" /> <a href="#how-it-works">Arbeitsweise</a></li>
81 </ul><h3>Siehe auch</h3>
83 <li><a href="../bind.html">Bestimmen der vom Apache verwendeten Adressen
86 <div class="top"><a href="#page-header"><img alt="top" src="../images/up.gif" /></a></div>
88 <h2><a name="how-it-works" id="how-it-works">Arbeitsweise</a></h2>
89 <p>Ein einzelner Steuerprozess (der Elternprozess) ist für den
90 Start der Kindprozesse verantwortlich. Jeder Kindprozess erstellt eine
91 feste Anzahl von Server-Threads, wie durch die <code class="directive"><a href="../mod/mpm_common.html#threadsperchild">ThreadsPerChild</a></code>-Direktive
92 angegeben, sowie einen "Listener-Thread", der auf Verbindungen wartet und
93 diese an einen Server-Thread zur Bearbeitung weiterreicht, sobald sie
96 <p>Der Apache versucht immer, einen Vorrat von <dfn>freien</dfn> oder
97 unbeschäftigten Threads zu verwalten, die zur Bedienung
98 hereinkommender Anfragen bereit stehen. Auf diese Weise brauchen
99 Clients nicht auf die Erstellung eines neuen Threads oder Prozesses
100 zu warten, bevor ihre Anfrage bedient werden kann. Die Anzahl der
101 Prozesse, die anfangs gestartet wird, wird mit der Direktive
102 <code class="directive"><a href="../mod/mpm_common.html#startservers">StartServers</a></code> festgelegt.
103 Dann, während des Betriebes, berechnet der Apache die Gesamtzahl
104 der unbeschäftigten Threads und forkt oder beendet Prozesse, um diese
105 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
106 zu halten. Da dieser Prozess sehr selbstregulierend ist, ist es nur selten
107 notwendig, die Voreinstellung dieser Direktiven zu ändern. Die
108 maximale Anzahl Clients, die gleichzeitig bedient werden kann (d.h.
109 die maximale Gesamtzahl der Threads in allen Prozessen), wird mit der
110 Direktive <code class="directive"><a href="../mod/mpm_common.html#maxclients">MaxClients</a></code>
111 festgelegt. Die maximale Anzahl der aktiven Kindprozesse ergibt sich aus
112 <code class="directive"><a href="../mod/mpm_common.html#maxclients">MaxClients</a></code> dividiert durch
113 <code class="directive"><a href="../mod/mpm_common.html#threadsperchild">ThreadsPerChild</a></code>.</p>
115 <p>Zwei Direktiven legen harte Limits für die Anzahl der aktiven
116 Kindprozesse fest und können nur geändert werden, indem der Server
117 komplett gestoppt und dann wieder neu gestartet wird. <code class="directive"><a href="../mod/mpm_common.html#serverlimit">ServerLimit</a></code> stellt die obere Grenze für
118 die Anzahl der aktiven Kindprozesse dar und muss größer oder
119 gleich dem Quotienten aus <code class="directive"><a href="../mod/mpm_common.html#maxclients">MaxClients</a></code> und <code class="directive"><a href="../mod/mpm_common.html#threadsperchild">ThreadsPerChild</a></code> sein. <code class="directive"><a href="../mod/mpm_common.html#threadlimit">ThreadLimit</a></code> ist die obere Grenze für
120 die Anzahl der Server-Threads und muss größer oder gleich
121 <code class="directive"><a href="../mod/mpm_common.html#threadsperchild">ThreadsPerChild</a></code> sein. Sofern für
122 diese Direktiven keine Voreinstellungen verwendet werden, sollten sie vor
123 allen anderen <code class="module"><a href="../mod/worker.html">worker</a></code>-Direktiven platziert werden.</p>
125 <p>Neben den normalen aktiven Kindprozessen gibt es möglicherweise noch
126 zusätzliche Kindprozesse, welche gerade beendet werden, wo allerdings
127 zumindest noch ein Server-Thread eine existierende Verbindung bearbeitet.
128 Obwohl die tatsächlich zu erwartende Anzahl deutlich kleiner ist,
129 können bis zu <code class="directive"><a href="../mod/mpm_common.html#maxclients">MaxClients</a></code>
130 solcher Prozesse auftreten. Dieses Verhalten können Sie vermeiden,
131 indem Sie die Terminierung einzelner Kindprozesse wie folgt abschalten:</p>
134 <li>setzen Sie den Wert von <code class="directive"><a href="../mod/mpm_common.html#maxrequestsperchild">MaxRequestsPerChild</a></code> auf Null</li>
136 <li>setzen Sie den Wert von <code class="directive"><a href="../mod/mpm_common.html#maxsparethreads">MaxSpareThreads</a></code> auf den gleichen Wert wie <code class="directive"><a href="../mod/mpm_common.html#maxclients">MaxClients</a></code></li>
139 <p>Eine typische Konfiguration der Prozess-Thread-Steuerung für
140 das MPM <code class="module"><a href="../mod/worker.html">worker</a></code> könnte wie folgt aussehen:</p>
142 <div class="example"><p><code>
146 MinSpareThreads 25<br />
147 MaxSpareThreads 75<br />
151 <p>Während der Elternprozess unter Unix normalerweise als
152 <code>root</code> gestartet wird, um sich an Port 80 binden zu können,
153 werden die Kindprozesse und Threads unter einem weniger privilegierten
154 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
155 Privilegien der Apache-Kindprozesse festzulegen. Die Kindprozesse
156 müssen in der Lage sein, alle Inhalte zu lesen, die sie ausliefern
157 sollen, sollten darüber hinaus jedoch so wenig wie möglich Rechte
158 besitzen. Zusätzlich, solange nicht <code class="program"><a href="../programs/suexec.html">suexec</a></code> verwendet wird, legen diese
159 Direktiven auch die Privilegien fest, die von CGI-Skripts
162 <p><code class="directive"><a href="../mod/mpm_common.html#maxrequestsperchild">MaxRequestsPerChild</a></code>
163 bestimmt, wie häufig der Server Prozesse erneuert, indem er alte
164 beendet und neue startet.</p>
167 <div class="bottomlang">
168 <p><span>Verfügbare Sprachen: </span><a href="../de/mod/worker.html" title="Deutsch"> de </a> |
169 <a href="../en/mod/worker.html" hreflang="en" rel="alternate" title="English"> en </a> |
170 <a href="../ja/mod/worker.html" hreflang="ja" rel="alternate" title="Japanese"> ja </a> |
171 <a href="../tr/mod/worker.html" hreflang="tr" rel="alternate" title="Türkçe"> tr </a></p>
172 </div><div id="footer">
173 <p class="apache">Copyright 2010 The Apache Software Foundation.<br />Lizenziert unter der <a href="http://www.apache.org/licenses/LICENSE-2.0">Apache License, Version 2.0</a>.</p>
174 <p class="menu"><a href="../mod/">Module</a> | <a href="../mod/directives.html">Direktiven</a> | <a href="../faq/">FAQ</a> | <a href="../glossary.html">Glossar</a> | <a href="../sitemap.html">Seitenindex</a></p></div>