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