upload apache
[bottlenecks.git] / rubbos / app / apache2 / manual / mod / worker.html.de
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
7       -->
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>
13 <body>
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.0</p>
17 <img alt="" src="../images/feather.gif" /></div>
18 <div class="up"><a href="./"><img title="&lt;-" alt="&lt;-" src="../images/left.gif" /></a></div>
19 <div id="path">
20 <a href="http://www.apache.org/">Apache</a> &gt; <a href="http://httpd.apache.org/">HTTP-Server</a> &gt; <a href="http://httpd.apache.org/docs/">Dokumentation</a> &gt; <a href="../">Version 2.0</a> &gt; <a href="./">Module</a></div>
21 <div id="page-content">
22 <div id="preamble"><h1>Apache-MPM worker</h1>
23 <div class="toplang">
24 <p><span>Verfügbare Sprachen: </span><a href="../de/mod/worker.html" title="Deutsch">&nbsp;de&nbsp;</a> |
25 <a href="../en/mod/worker.html" hreflang="en" rel="alternate" title="English">&nbsp;en&nbsp;</a> |
26 <a href="../es/mod/worker.html" hreflang="es" rel="alternate" title="Español">&nbsp;es&nbsp;</a> |
27 <a href="../ja/mod/worker.html" hreflang="ja" rel="alternate" title="Japanese">&nbsp;ja&nbsp;</a> |
28 <a href="../tr/mod/worker.html" hreflang="tr" rel="alternate" title="Türkçe">&nbsp;tr&nbsp;</a></p>
29 </div>
30 <table class="module"><tr><th><a href="module-dict.html#Description">Beschreibung:</a></th><td>Multi-Processing-Modul, das einen Hybrid-Webserver mit
31   Multi-Thread und Multi-Prozess-Unterstützung implementiert</td></tr>
32 <tr><th><a href="module-dict.html#Status">Status:</a></th><td>MPM</td></tr>
33 <tr><th><a href="module-dict.html#ModuleIdentifier">Modulbezeichner:</a></th><td>mpm_worker_module</td></tr>
34 <tr><th><a href="module-dict.html#SourceFile">Quelltext-Datei:</a></th><td>worker.c</td></tr></table>
35 <h3>Zusammenfassung</h3>
36
37     <p>Dieses Multi-Processing-Modul (MPM) implementiert einen Hybrid-Server
38     mit Multi-Thread und Multi-Prozess-Unterstützung. Durch die Verwendung
39     von Threads für die Bedienung von Anfragen ist er in der Lage,
40     eine große Anzahl von Anfragen mit weniger Systemressourcen als
41     ein Prozess-basierter Server zu bedienen. Er behält jedoch viel von
42     der Stabilität eines Prozess-basierten Servers bei, indem er
43     mehrere Prozesse verfügbar hält, jeden mit etlichen Threads.</p>
44
45     <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
46     der Threads beeinflusst, die von jedem Kindprozess verwendet werden, und
47     <code class="directive"><a href="../mod/mpm_common.html#maxclients">MaxClients</a></code>, welche die
48     maximale Gesamtzahl an Threads regelt, die gestartet werden
49     können.</p>
50 </div>
51 <div id="quickview"><h3 class="directives">Direktiven</h3>
52 <ul id="toc">
53 <li><img alt="" src="../images/right.gif" /> <a href="mpm_common.html#acceptmutex">AcceptMutex</a></li>
54 <li><img alt="" src="../images/right.gif" /> <a href="mpm_common.html#coredumpdirectory">CoreDumpDirectory</a></li>
55 <li><img alt="" src="../images/right.gif" /> <a href="mpm_common.html#enableexceptionhook">EnableExceptionHook</a></li>
56 <li><img alt="" src="../images/right.gif" /> <a href="mpm_common.html#group">Group</a></li>
57 <li><img alt="" src="../images/right.gif" /> <a href="mpm_common.html#listen">Listen</a></li>
58 <li><img alt="" src="../images/right.gif" /> <a href="mpm_common.html#listenbacklog">ListenBacklog</a></li>
59 <li><img alt="" src="../images/right.gif" /> <a href="mpm_common.html#lockfile">LockFile</a></li>
60 <li><img alt="" src="../images/right.gif" /> <a href="mpm_common.html#maxclients">MaxClients</a></li>
61 <li><img alt="" src="../images/right.gif" /> <a href="mpm_common.html#maxmemfree">MaxMemFree</a></li>
62 <li><img alt="" src="../images/right.gif" /> <a href="mpm_common.html#maxrequestsperchild">MaxRequestsPerChild</a></li>
63 <li><img alt="" src="../images/right.gif" /> <a href="mpm_common.html#maxsparethreads">MaxSpareThreads</a></li>
64 <li><img alt="" src="../images/right.gif" /> <a href="mpm_common.html#minsparethreads">MinSpareThreads</a></li>
65 <li><img alt="" src="../images/right.gif" /> <a href="mpm_common.html#pidfile">PidFile</a></li>
66 <li><img alt="" src="../images/right.gif" /> <a href="mpm_common.html#receivebuffersize">ReceiveBufferSize</a></li>
67 <li><img alt="" src="../images/right.gif" /> <a href="mpm_common.html#scoreboardfile">ScoreBoardFile</a></li>
68 <li><img alt="" src="../images/right.gif" /> <a href="mpm_common.html#sendbuffersize">SendBufferSize</a></li>
69 <li><img alt="" src="../images/right.gif" /> <a href="mpm_common.html#serverlimit">ServerLimit</a></li>
70 <li><img alt="" src="../images/right.gif" /> <a href="mpm_common.html#startservers">StartServers</a></li>
71 <li><img alt="" src="../images/right.gif" /> <a href="mpm_common.html#threadlimit">ThreadLimit</a></li>
72 <li><img alt="" src="../images/right.gif" /> <a href="mpm_common.html#threadsperchild">ThreadsPerChild</a></li>
73 <li><img alt="" src="../images/right.gif" /> <a href="mpm_common.html#user">User</a></li>
74 </ul>
75 <h3>Themen</h3>
76 <ul id="topics">
77 <li><img alt="" src="../images/down.gif" /> <a href="#how-it-works">Arbeitsweise</a></li>
78 </ul><h3>Siehe auch</h3>
79 <ul class="seealso">
80 <li><a href="../bind.html">Bestimmen der vom Apache verwendeten Adressen
81   und Ports</a></li>
82 </ul></div>
83 <div class="top"><a href="#page-header"><img alt="top" src="../images/up.gif" /></a></div>
84 <div class="section">
85 <h2><a name="how-it-works" id="how-it-works">Arbeitsweise</a></h2>
86     <p>Ein einzelner Steuerprozess (der Elternprozess) ist für den
87     Start der Kindprozesse verantwortlich. Jeder Kindprozess erstellt eine
88     feste Anzahl von Server-Threads, wie durch die <code class="directive"><a href="../mod/mpm_common.html#threadsperchild">ThreadsPerChild</a></code>-Direktive
89     angegeben, sowie einen "Listener-Thread", der auf Verbindungen wartet und
90     diese an einen Server-Thread zur Bearbeitung weiterreicht, sobald sie
91     eintreffen.</p>
92
93     <p>Der Apache versucht immer, einen Vorrat von <dfn>freien</dfn> oder
94     unbeschäftigten Threads zu verwalten, die zur Bedienung
95     hereinkommender Anfragen bereit stehen. Auf diese Weise brauchen
96     Clients nicht auf die Erstellung eines neuen Threads oder Prozesses
97     zu warten, bevor ihre Anfrage bedient werden kann. Die Anzahl der
98     Prozesse, die anfangs gestartet wird, wird mit der Direktive
99     <code class="directive"><a href="../mod/mpm_common.html#startservers">StartServers</a></code> festgelegt.
100     Dann, während des Betriebes, berechnet der Apache die Gesamtzahl
101     der unbeschäftigten Threads und forkt oder beendet Prozesse, um diese
102     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
103     zu halten. Da dieser Prozess sehr selbstregulierend ist, ist es nur selten
104     notwendig, die Voreinstellung dieser Direktiven zu ändern. Die
105     maximale Anzahl Clients, die gleichzeitig bedient werden kann (d.h.
106     die maximale Gesamtzahl der Threads in allen Prozessen), wird mit der
107     Direktive <code class="directive"><a href="../mod/mpm_common.html#maxclients">MaxClients</a></code>
108     festgelegt. Die maximale Anzahl der aktiven Kindprozesse ergibt sich aus
109     <code class="directive"><a href="../mod/mpm_common.html#maxclients">MaxClients</a></code> dividiert durch
110     <code class="directive"><a href="../mod/mpm_common.html#threadsperchild">ThreadsPerChild</a></code>.</p>
111
112     <p>Zwei Direktiven legen harte Limits für die Anzahl der aktiven
113     Kindprozesse fest und können nur geändert werden, indem der Server
114     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
115     die Anzahl der aktiven Kindprozesse dar und muss größer oder
116     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
117     die Anzahl der Server-Threads und muss größer oder gleich
118     <code class="directive"><a href="../mod/mpm_common.html#threadsperchild">ThreadsPerChild</a></code> sein. Sofern für
119     diese Direktiven keine Voreinstellungen verwendet werden, sollten sie vor
120     allen anderen <code class="module"><a href="../mod/worker.html">worker</a></code>-Direktiven platziert werden.</p>
121
122     <p>Neben den normalen aktiven Kindprozessen gibt es möglicherweise noch
123     zusätzliche Kindprozesse, welche gerade beendet werden, wo allerdings
124     zumindest noch ein Server-Thread eine existierende Verbindung bearbeitet.
125     Obwohl die tatsächlich zu erwartende Anzahl deutlich kleiner ist,
126     können bis zu <code class="directive"><a href="../mod/mpm_common.html#maxclients">MaxClients</a></code>
127     solcher Prozesse auftreten. Dieses Verhalten können Sie vermeiden,
128     indem Sie die Terminierung einzelner Kindprozesse wie folgt abschalten:</p>
129
130     <ul>
131        <li>setzen Sie den Wert von <code class="directive"><a href="../mod/mpm_common.html#maxrequestsperchild">MaxRequestsPerChild</a></code> auf Null</li>
132
133        <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>
134     </ul>
135
136     <p>Eine typische Konfiguration der Prozess-Thread-Steuerung für
137     das MPM <code class="module"><a href="../mod/worker.html">worker</a></code> könnte wie folgt aussehen:</p>
138
139     <div class="example"><p><code>
140       ServerLimit         16<br />
141       StartServers         2<br />
142       MaxClients         150<br />
143       MinSpareThreads     25<br />
144       MaxSpareThreads     75<br />
145       ThreadsPerChild     25
146     </code></p></div>
147
148     <p>Während der Elternprozess unter Unix normalerweise als
149     <code>root</code> gestartet wird, um sich an Port 80 binden zu können,
150     werden die Kindprozesse und Threads unter einem weniger privilegierten
151     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
152     Privilegien der Apache-Kindprozesse festzulegen. Die Kindprozesse
153     müssen in der Lage sein, alle Inhalte zu lesen, die sie ausliefern
154     sollen, sollten darüber hinaus jedoch so wenig wie möglich Rechte
155     besitzen. Zusätzlich, solange nicht <code class="program"><a href="../programs/suexec.html">suexec</a></code> verwendet wird, legen diese
156     Direktiven auch die Privilegien fest, die von CGI-Skripts
157     geerbt werden.</p>
158
159     <p><code class="directive"><a href="../mod/mpm_common.html#maxrequestsperchild">MaxRequestsPerChild</a></code>
160     bestimmt, wie häufig der Server Prozesse erneuert, indem er alte
161     beendet und neue startet.</p>
162 </div>
163 </div>
164 <div class="bottomlang">
165 <p><span>Verfügbare Sprachen: </span><a href="../de/mod/worker.html" title="Deutsch">&nbsp;de&nbsp;</a> |
166 <a href="../en/mod/worker.html" hreflang="en" rel="alternate" title="English">&nbsp;en&nbsp;</a> |
167 <a href="../es/mod/worker.html" hreflang="es" rel="alternate" title="Español">&nbsp;es&nbsp;</a> |
168 <a href="../ja/mod/worker.html" hreflang="ja" rel="alternate" title="Japanese">&nbsp;ja&nbsp;</a> |
169 <a href="../tr/mod/worker.html" hreflang="tr" rel="alternate" title="Türkçe">&nbsp;tr&nbsp;</a></p>
170 </div><div id="footer">
171 <p class="apache">Copyright 2009 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>
172 <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>
173 </body></html>