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