]> granicus.if.org Git - apache/blob - docs/manual/mod/worker.html.de
XML update.
[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 <meta content="text/html; charset=ISO-8859-1" http-equiv="Content-Type" />
5 <!--
6         XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX
7               This file is generated from xml source: DO NOT EDIT
8         XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX
9       -->
10 <title>worker - Apache HTTP Server Version 2.5</title>
11 <link href="../style/css/manual.css" rel="stylesheet" media="all" type="text/css" title="Main stylesheet" />
12 <link href="../style/css/manual-loose-100pc.css" rel="alternate stylesheet" media="all" type="text/css" title="No Sidebar - Default font size" />
13 <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" />
14 <script src="../style/scripts/prettify.min.js" type="text/javascript">
15 </script>
16
17 <link href="../images/favicon.ico" rel="shortcut icon" /></head>
18 <body>
19 <div id="page-header">
20 <p class="menu"><a href="../mod/">Module</a> | <a href="../mod/quickreference.html">Direktiven</a> | <a href="http://wiki.apache.org/httpd/FAQ">FAQ</a> | <a href="../glossary.html">Glossar</a> | <a href="../sitemap.html">Seitenindex</a></p>
21 <p class="apache">Apache HTTP Server Version 2.5</p>
22 <img alt="" src="../images/feather.png" /></div>
23 <div class="up"><a href="./"><img title="&lt;-" alt="&lt;-" src="../images/left.gif" /></a></div>
24 <div id="path">
25 <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>
26 <div id="page-content">
27 <div id="preamble"><h1>Apache-MPM worker</h1>
28 <div class="toplang">
29 <p><span>Verfügbare Sprachen: </span><a href="../de/mod/worker.html" title="Deutsch">&nbsp;de&nbsp;</a> |
30 <a href="../en/mod/worker.html" hreflang="en" rel="alternate" title="English">&nbsp;en&nbsp;</a> |
31 <a href="../fr/mod/worker.html" hreflang="fr" rel="alternate" title="Français">&nbsp;fr&nbsp;</a> |
32 <a href="../ja/mod/worker.html" hreflang="ja" rel="alternate" title="Japanese">&nbsp;ja&nbsp;</a> |
33 <a href="../tr/mod/worker.html" hreflang="tr" rel="alternate" title="Türkçe">&nbsp;tr&nbsp;</a></p>
34 </div>
35 <div class="outofdate">Diese Übersetzung ist möglicherweise
36             nicht mehr aktuell. Bitte prüfen Sie die englische Version auf
37             die neuesten Änderungen.</div>
38 <table class="module"><tr><th><a href="module-dict.html#Description">Beschreibung:</a></th><td>Multi-Processing-Modul, das einen Hybrid-Webserver mit
39   Multi-Thread und Multi-Prozess-Unterstützung implementiert</td></tr>
40 <tr><th><a href="module-dict.html#Status">Status:</a></th><td>MPM</td></tr>
41 <tr><th><a href="module-dict.html#ModuleIdentifier">Modulbezeichner:</a></th><td>mpm_worker_module</td></tr>
42 <tr><th><a href="module-dict.html#SourceFile">Quelltext-Datei:</a></th><td>worker.c</td></tr></table>
43 <h3>Zusammenfassung</h3>
44
45     <p>Dieses Multi-Processing-Modul (MPM) implementiert einen Hybrid-Server
46     mit Multi-Thread und Multi-Prozess-Unterstützung. Durch die Verwendung
47     von Threads für die Bedienung von Anfragen ist er in der Lage,
48     eine große Anzahl von Anfragen mit weniger Systemressourcen als
49     ein Prozess-basierter Server zu bedienen. Er behält jedoch viel von
50     der Stabilität eines Prozess-basierten Servers bei, indem er
51     mehrere Prozesse verfügbar hält, jeden mit etlichen Threads.</p>
52
53     <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
54     der Threads beeinflusst, die von jedem Kindprozess verwendet werden, und
55     <code class="directive"><a href="../mod/mpm_common.html#maxclients">MaxClients</a></code>, welche die
56     maximale Gesamtzahl an Threads regelt, die gestartet werden
57     können.</p>
58 </div>
59 <div id="quickview"><h3>Themen</h3>
60 <ul id="topics">
61 <li><img alt="" src="../images/down.gif" /> <a href="#how-it-works">Arbeitsweise</a></li>
62 </ul><h3 class="directives">Direktiven</h3>
63 <ul id="toc">
64 <li><img alt="" src="../images/right.gif" /> <a href="mpm_common.html#coredumpdirectory">CoreDumpDirectory</a></li>
65 <li><img alt="" src="../images/right.gif" /> <a href="mpm_common.html#enableexceptionhook">EnableExceptionHook</a></li>
66 <li><img alt="" src="../images/right.gif" /> <a href="mod_unixd.html#group">Group</a></li>
67 <li><img alt="" src="../images/right.gif" /> <a href="mpm_common.html#listen">Listen</a></li>
68 <li><img alt="" src="../images/right.gif" /> <a href="mpm_common.html#listenbacklog">ListenBacklog</a></li>
69 <li><img alt="" src="../images/right.gif" /> <a href="mpm_common.html#maxconnectionsperchild">MaxConnectionsPerChild</a></li>
70 <li><img alt="" src="../images/right.gif" /> <a href="mpm_common.html#maxmemfree">MaxMemFree</a></li>
71 <li><img alt="" src="../images/right.gif" /> <a href="mpm_common.html#maxrequestworkers">MaxRequestWorkers</a></li>
72 <li><img alt="" src="../images/right.gif" /> <a href="mpm_common.html#maxsparethreads">MaxSpareThreads</a></li>
73 <li><img alt="" src="../images/right.gif" /> <a href="mpm_common.html#minsparethreads">MinSpareThreads</a></li>
74 <li><img alt="" src="../images/right.gif" /> <a href="mpm_common.html#pidfile">PidFile</a></li>
75 <li><img alt="" src="../images/right.gif" /> <a href="mpm_common.html#receivebuffersize">ReceiveBufferSize</a></li>
76 <li><img alt="" src="../images/right.gif" /> <a href="mpm_common.html#scoreboardfile">ScoreBoardFile</a></li>
77 <li><img alt="" src="../images/right.gif" /> <a href="mpm_common.html#sendbuffersize">SendBufferSize</a></li>
78 <li><img alt="" src="../images/right.gif" /> <a href="mpm_common.html#serverlimit">ServerLimit</a></li>
79 <li><img alt="" src="../images/right.gif" /> <a href="mpm_common.html#startservers">StartServers</a></li>
80 <li><img alt="" src="../images/right.gif" /> <a href="mpm_common.html#threadlimit">ThreadLimit</a></li>
81 <li><img alt="" src="../images/right.gif" /> <a href="mpm_common.html#threadsperchild">ThreadsPerChild</a></li>
82 <li><img alt="" src="../images/right.gif" /> <a href="mpm_common.html#threadstacksize">ThreadStackSize</a></li>
83 <li><img alt="" src="../images/right.gif" /> <a href="mod_unixd.html#user">User</a></li>
84 </ul>
85 <h3>Bugfix checklist</h3><ul class="seealso"><li><a href="https://www.apache.org/dist/httpd/CHANGES_2.4">httpd changelog</a></li><li><a href="https://bz.apache.org/bugzilla/buglist.cgi?bug_status=__open__&amp;list_id=144532&amp;product=Apache%20httpd-2&amp;query_format=specific&amp;order=changeddate%20DESC%2Cpriority%2Cbug_severity&amp;component=mpm_worker">Known issues</a></li><li><a href="https://bz.apache.org/bugzilla/enter_bug.cgi?product=Apache%20httpd-2&amp;component=mpm_worker">Report a bug</a></li></ul><h3>Siehe auch</h3>
86 <ul class="seealso">
87 <li><a href="../bind.html">Bestimmen der vom Apache verwendeten Adressen
88   und Ports</a></li>
89 <li><a href="#comments_section">Kommentare</a></li></ul></div>
90 <div class="top"><a href="#page-header"><img alt="top" src="../images/up.gif" /></a></div>
91 <div class="section">
92 <h2><a name="how-it-works" id="how-it-works">Arbeitsweise</a><a title="Permanent link" href="#how-it-works" class="permalink">&para;</a></h2>
93     <p>Ein einzelner Steuerprozess (der Elternprozess) ist für den
94     Start der Kindprozesse verantwortlich. Jeder Kindprozess erstellt eine
95     feste Anzahl von Server-Threads, wie durch die <code class="directive"><a href="../mod/mpm_common.html#threadsperchild">ThreadsPerChild</a></code>-Direktive
96     angegeben, sowie einen "Listener-Thread", der auf Verbindungen wartet und
97     diese an einen Server-Thread zur Bearbeitung weiterreicht, sobald sie
98     eintreffen.</p>
99
100     <p>Der Apache versucht immer, einen Vorrat von <dfn>freien</dfn> oder
101     unbeschäftigten Threads zu verwalten, die zur Bedienung
102     hereinkommender Anfragen bereit stehen. Auf diese Weise brauchen
103     Clients nicht auf die Erstellung eines neuen Threads oder Prozesses
104     zu warten, bevor ihre Anfrage bedient werden kann. Die Anzahl der
105     Prozesse, die anfangs gestartet wird, wird mit der Direktive
106     <code class="directive"><a href="../mod/mpm_common.html#startservers">StartServers</a></code> festgelegt.
107     Dann, während des Betriebes, berechnet der Apache die Gesamtzahl
108     der unbeschäftigten Threads und forkt oder beendet Prozesse, um diese
109     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
110     zu halten. Da dieser Prozess sehr selbstregulierend ist, ist es nur selten
111     notwendig, die Voreinstellung dieser Direktiven zu ändern. Die
112     maximale Anzahl Clients, die gleichzeitig bedient werden kann (d.h.
113     die maximale Gesamtzahl der Threads in allen Prozessen), wird mit der
114     Direktive <code class="directive"><a href="../mod/mpm_common.html#maxclients">MaxClients</a></code>
115     festgelegt. Die maximale Anzahl der aktiven Kindprozesse ergibt sich aus
116     <code class="directive"><a href="../mod/mpm_common.html#maxclients">MaxClients</a></code> dividiert durch
117     <code class="directive"><a href="../mod/mpm_common.html#threadsperchild">ThreadsPerChild</a></code>.</p>
118
119     <p>Zwei Direktiven legen harte Limits für die Anzahl der aktiven
120     Kindprozesse fest und können nur geändert werden, indem der Server
121     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
122     die Anzahl der aktiven Kindprozesse dar und muss größer oder
123     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
124     die Anzahl der Server-Threads und muss größer oder gleich
125     <code class="directive"><a href="../mod/mpm_common.html#threadsperchild">ThreadsPerChild</a></code> sein. Sofern für
126     diese Direktiven keine Voreinstellungen verwendet werden, sollten sie vor
127     allen anderen <code class="module"><a href="../mod/worker.html">worker</a></code>-Direktiven platziert werden.</p>
128
129     <p>Neben den normalen aktiven Kindprozessen gibt es möglicherweise noch
130     zusätzliche Kindprozesse, welche gerade beendet werden, wo allerdings
131     zumindest noch ein Server-Thread eine existierende Verbindung bearbeitet.
132     Obwohl die tatsächlich zu erwartende Anzahl deutlich kleiner ist,
133     können bis zu <code class="directive"><a href="../mod/mpm_common.html#maxclients">MaxClients</a></code>
134     solcher Prozesse auftreten. Dieses Verhalten können Sie vermeiden,
135     indem Sie die Terminierung einzelner Kindprozesse wie folgt abschalten:</p>
136
137     <ul>
138        <li>setzen Sie den Wert von <code class="directive"><a href="../mod/mpm_common.html#maxrequestsperchild">MaxRequestsPerChild</a></code> auf Null</li>
139
140        <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>
141     </ul>
142
143     <p>Eine typische Konfiguration der Prozess-Thread-Steuerung für
144     das MPM <code class="module"><a href="../mod/worker.html">worker</a></code> könnte wie folgt aussehen:</p>
145
146     <div class="example"><p><code>
147       ServerLimit         16<br />
148       StartServers         2<br />
149       MaxClients         150<br />
150       MinSpareThreads     25<br />
151       MaxSpareThreads     75<br />
152       ThreadsPerChild     25
153     </code></p></div>
154
155     <p>Während der Elternprozess unter Unix normalerweise als
156     <code>root</code> gestartet wird, um sich an Port 80 binden zu können,
157     werden die Kindprozesse und Threads unter einem weniger privilegierten
158     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
159     Privilegien der Apache-Kindprozesse festzulegen. Die Kindprozesse
160     müssen in der Lage sein, alle Inhalte zu lesen, die sie ausliefern
161     sollen, sollten darüber hinaus jedoch so wenig wie möglich Rechte
162     besitzen. Zusätzlich, solange nicht <code class="program"><a href="../programs/suexec.html">suexec</a></code> verwendet wird, legen diese
163     Direktiven auch die Privilegien fest, die von CGI-Skripts
164     geerbt werden.</p>
165
166     <p><code class="directive"><a href="../mod/mpm_common.html#maxrequestsperchild">MaxRequestsPerChild</a></code>
167     bestimmt, wie häufig der Server Prozesse erneuert, indem er alte
168     beendet und neue startet.</p>
169 </div>
170 </div>
171 <div class="bottomlang">
172 <p><span>Verfügbare Sprachen: </span><a href="../de/mod/worker.html" title="Deutsch">&nbsp;de&nbsp;</a> |
173 <a href="../en/mod/worker.html" hreflang="en" rel="alternate" title="English">&nbsp;en&nbsp;</a> |
174 <a href="../fr/mod/worker.html" hreflang="fr" rel="alternate" title="Français">&nbsp;fr&nbsp;</a> |
175 <a href="../ja/mod/worker.html" hreflang="ja" rel="alternate" title="Japanese">&nbsp;ja&nbsp;</a> |
176 <a href="../tr/mod/worker.html" hreflang="tr" rel="alternate" title="Türkçe">&nbsp;tr&nbsp;</a></p>
177 </div><div class="top"><a href="#page-header"><img src="../images/up.gif" alt="top" /></a></div><div class="section"><h2><a id="comments_section" name="comments_section">Kommentare</a></h2><div class="warning"><strong>Notice:</strong><br />This is not a Q&amp;A section. Comments placed here should be pointed towards suggestions on improving the documentation or server, and may be removed again by our moderators if they are either implemented or considered invalid/off-topic. Questions on how to manage the Apache HTTP Server should be directed at either our IRC channel, #httpd, on Freenode, or sent to our <a href="http://httpd.apache.org/lists.html">mailing lists</a>.</div>
178 <script type="text/javascript"><!--//--><![CDATA[//><!--
179 var comments_shortname = 'httpd';
180 var comments_identifier = 'http://httpd.apache.org/docs/trunk/mod/worker.html';
181 (function(w, d) {
182     if (w.location.hostname.toLowerCase() == "httpd.apache.org") {
183         d.write('<div id="comments_thread"><\/div>');
184         var s = d.createElement('script');
185         s.type = 'text/javascript';
186         s.async = true;
187         s.src = 'https://comments.apache.org/show_comments.lua?site=' + comments_shortname + '&page=' + comments_identifier;
188         (d.getElementsByTagName('head')[0] || d.getElementsByTagName('body')[0]).appendChild(s);
189     }
190     else {
191         d.write('<div id="comments_thread">Comments are disabled for this page at the moment.<\/div>');
192     }
193 })(window, document);
194 //--><!]]></script></div><div id="footer">
195 <p class="apache">Copyright 2018 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>
196 <p class="menu"><a href="../mod/">Module</a> | <a href="../mod/quickreference.html">Direktiven</a> | <a href="http://wiki.apache.org/httpd/FAQ">FAQ</a> | <a href="../glossary.html">Glossar</a> | <a href="../sitemap.html">Seitenindex</a></p></div><script type="text/javascript"><!--//--><![CDATA[//><!--
197 if (typeof(prettyPrint) !== 'undefined') {
198     prettyPrint();
199 }
200 //--><!]]></script>
201 </body></html>