1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
|
<?xml version="1.0"?>
<!DOCTYPE modulesynopsis SYSTEM "../style/modulesynopsis.dtd">
<?xml-stylesheet type="text/xsl" href="../style/manual.de.xsl"?>
<!-- English Revision: 280384:395228 (outdated) -->
<!--
Licensed to the Apache Software Foundation (ASF) under one or more
contributor license agreements. See the NOTICE file distributed with
this work for additional information regarding copyright ownership.
The ASF licenses this file to You under the Apache License, Version 2.0
(the "License"); you may not use this file except in compliance with
the License. You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.
-->
<modulesynopsis metafile="worker.xml.meta">
<name>worker</name>
<description>Multi-Processing-Modul, das einen Hybrid-Webserver mit
Multi-Thread und Multi-Prozess-Unterstützung implementiert</description>
<status>MPM</status>
<sourcefile>worker.c</sourcefile>
<identifier>mpm_worker_module</identifier>
<summary>
<p>Dieses Multi-Processing-Modul (MPM) implementiert einen Hybrid-Server
mit Multi-Thread und Multi-Prozess-Unterstützung. Durch die Verwendung
von Threads für die Bedienung von Anfragen ist er in der Lage,
eine große Anzahl von Anfragen mit weniger Systemressourcen als
ein Prozess-basierter Server zu bedienen. Er behält jedoch viel von
der Stabilität eines Prozess-basierten Servers bei, indem er
mehrere Prozesse verfügbar hält, jeden mit etlichen Threads.</p>
<p>Die wichtigsten Direktiven zur Steuerung des MPMs sind <directive
module="mpm_common">ThreadsPerChild</directive>, welche die Anzahl
der Threads beeinflusst, die von jedem Kindprozess verwendet werden, und
<directive module="mpm_common">MaxClients</directive>, welche die
maximale Gesamtzahl an Threads regelt, die gestartet werden
können.</p>
</summary>
<seealso><a href="../bind.html">Bestimmen der vom Apache verwendeten Adressen
und Ports</a></seealso>
<section id="how-it-works"><title>Arbeitsweise</title>
<p>Ein einzelner Steuerprozess (der Elternprozess) ist für den
Start der Kindprozesse verantwortlich. Jeder Kindprozess erstellt eine
feste Anzahl von Server-Threads, wie durch die <directive
module="mpm_common">ThreadsPerChild</directive>-Direktive
angegeben, sowie einen "Listener-Thread", der auf Verbindungen wartet und
diese an einen Server-Thread zur Bearbeitung weiterreicht, sobald sie
eintreffen.</p>
<p>Der Apache versucht immer, einen Vorrat von <dfn>freien</dfn> oder
unbeschäftigten Threads zu verwalten, die zur Bedienung
hereinkommender Anfragen bereit stehen. Auf diese Weise brauchen
Clients nicht auf die Erstellung eines neuen Threads oder Prozesses
zu warten, bevor ihre Anfrage bedient werden kann. Die Anzahl der
Prozesse, die anfangs gestartet wird, wird mit der Direktive
<directive module="mpm_common">StartServers</directive> festgelegt.
Dann, während des Betriebes, berechnet der Apache die Gesamtzahl
der unbeschäftigten Threads und forkt oder beendet Prozesse, um diese
Anzahl innerhalb der durch <directive
module="mpm_common">MinSpareThreads</directive> und <directive
module="mpm_common">MaxSpareThreads</directive> angegebenen Grenzen
zu halten. Da dieser Prozess sehr selbstregulierend ist, ist es nur selten
notwendig, die Voreinstellung dieser Direktiven zu ändern. Die
maximale Anzahl Clients, die gleichzeitig bedient werden kann (d.h.
die maximale Gesamtzahl der Threads in allen Prozessen), wird mit der
Direktive <directive module="mpm_common">MaxClients</directive>
festgelegt. Die maximale Anzahl der aktiven Kindprozesse ergibt sich aus
<directive module="mpm_common">MaxClients</directive> dividiert durch
<directive module="mpm_common">ThreadsPerChild</directive>.</p>
<p>Zwei Direktiven legen harte Limits für die Anzahl der aktiven
Kindprozesse fest und können nur geändert werden, indem der Server
komplett gestoppt und dann wieder neu gestartet wird. <directive
module="mpm_common">ServerLimit</directive> stellt die obere Grenze für
die Anzahl der aktiven Kindprozesse dar und muss größer oder
gleich dem Quotienten aus <directive
module="mpm_common">MaxClients</directive> und <directive
module="mpm_common">ThreadsPerChild</directive> sein. <directive
module="mpm_common">ThreadLimit</directive> ist die obere Grenze für
die Anzahl der Server-Threads und muss größer oder gleich
<directive module="mpm_common">ThreadsPerChild</directive> sein. Sofern für
diese Direktiven keine Voreinstellungen verwendet werden, sollten sie vor
allen anderen <module>worker</module>-Direktiven platziert werden.</p>
<p>Neben den normalen aktiven Kindprozessen gibt es möglicherweise noch
zusätzliche Kindprozesse, welche gerade beendet werden, wo allerdings
zumindest noch ein Server-Thread eine existierende Verbindung bearbeitet.
Obwohl die tatsächlich zu erwartende Anzahl deutlich kleiner ist,
können bis zu <directive module="mpm_common">MaxClients</directive>
solcher Prozesse auftreten. Dieses Verhalten können Sie vermeiden,
indem Sie die Terminierung einzelner Kindprozesse wie folgt abschalten:</p>
<ul>
<li>setzen Sie den Wert von <directive module="mpm_common"
>MaxRequestsPerChild</directive> auf Null</li>
<li>setzen Sie den Wert von <directive module="mpm_common"
>MaxSpareThreads</directive> auf den gleichen Wert wie <directive
module="mpm_common">MaxClients</directive></li>
</ul>
<p>Eine typische Konfiguration der Prozess-Thread-Steuerung für
das MPM <module>worker</module> könnte wie folgt aussehen:</p>
<example>
ServerLimit 16<br />
StartServers 2<br />
MaxClients 150<br />
MinSpareThreads 25<br />
MaxSpareThreads 75<br />
ThreadsPerChild 25
</example>
<p>Während der Elternprozess unter Unix normalerweise als
<code>root</code> gestartet wird, um sich an Port 80 binden zu können,
werden die Kindprozesse und Threads unter einem weniger privilegierten
Benutzer gestartet. Die Direktiven <directive
module="mpm_common">User</directive> und <directive
module="mpm_common">Group</directive> werden dazu verwendet, die
Privilegien der Apache-Kindprozesse festzulegen. Die Kindprozesse
müssen in der Lage sein, alle Inhalte zu lesen, die sie ausliefern
sollen, sollten darüber hinaus jedoch so wenig wie möglich Rechte
besitzen. Zusätzlich, solange nicht <program>
suexec</program> verwendet wird, legen diese
Direktiven auch die Privilegien fest, die von CGI-Skripts
geerbt werden.</p>
<p><directive module="mpm_common">MaxRequestsPerChild</directive>
bestimmt, wie häufig der Server Prozesse erneuert, indem er alte
beendet und neue startet.</p>
</section>
<directivesynopsis location="mpm_common"><name>AcceptMutex</name>
</directivesynopsis>
<directivesynopsis location="mpm_common"><name>CoreDumpDirectory</name>
</directivesynopsis>
<directivesynopsis location="mpm_common"><name>EnableExceptionHook</name>
</directivesynopsis>
<directivesynopsis location="mpm_common"><name>Group</name>
</directivesynopsis>
<directivesynopsis location="mpm_common"><name>PidFile</name>
</directivesynopsis>
<directivesynopsis location="mpm_common"><name>Listen</name>
</directivesynopsis>
<directivesynopsis location="mpm_common"><name>ListenBacklog</name>
</directivesynopsis>
<directivesynopsis location="mpm_common"><name>LockFile</name>
</directivesynopsis>
<directivesynopsis location="mpm_common"><name>MaxClients</name>
</directivesynopsis>
<directivesynopsis location="mpm_common"><name>MaxMemFree</name>
</directivesynopsis>
<directivesynopsis location="mpm_common"><name>MaxRequestsPerChild</name>
</directivesynopsis>
<directivesynopsis location="mpm_common"><name>MaxSpareThreads</name>
</directivesynopsis>
<directivesynopsis location="mpm_common"><name>MinSpareThreads</name>
</directivesynopsis>
<directivesynopsis location="mpm_common"><name>ScoreBoardFile</name>
</directivesynopsis>
<directivesynopsis location="mpm_common"><name>ReceiveBufferSize</name>
</directivesynopsis>
<directivesynopsis location="mpm_common"><name>SendBufferSize</name>
</directivesynopsis>
<directivesynopsis location="mpm_common"><name>ServerLimit</name>
</directivesynopsis>
<directivesynopsis location="mpm_common"><name>StartServers</name>
</directivesynopsis>
<directivesynopsis location="mpm_common"><name>ThreadLimit</name>
</directivesynopsis>
<directivesynopsis location="mpm_common"><name>ThreadsPerChild</name>
</directivesynopsis>
<directivesynopsis location="mpm_common"><name>ThreadStackSize</name>
</directivesynopsis>
<directivesynopsis location="mpm_common"><name>User</name>
</directivesynopsis>
</modulesynopsis>
|