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