Äîêóìåíò âçÿò èç êýøà ïîèñêîâîé ìàøèíû. Àäðåñ îðèãèíàëüíîãî äîêóìåíòà : http://itpm.msu.su/manual/de/mod/worker.html
Äàòà èçìåíåíèÿ: Sat Feb 5 01:50:17 2005
Äàòà èíäåêñèðîâàíèÿ: Mon Oct 1 22:29:24 2012
Êîäèðîâêà:
worker - Apache HTTP Server
<-
Apache > HTTP-Server > Dokumentation > Version 2.0 > Module

Apache-MPM worker

VerfÝgbare Sprachen:  de  |  en  |  es  |  ja 

Beschreibung:Multi-Processing-Modul, das einen Hybrid-Webserver mit Multi-Thread und Multi-Prozess-UnterstÝtzung implementiert
Status:MPM
Modulbezeichner:mpm_worker_module
Quelltext-Datei:worker.c

Zusammenfassung

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.

Die wichtigsten Direktiven zur Steuerung des MPMs sind ThreadsPerChild, welche die Anzahl der Threads beeinflusst, die von jedem Kindprozess verwendet werden, und MaxClients, welche die maximale Gesamtzahl an Threads regelt, die gestartet werden kÆnnen.

Direktiven

Themen

Siehe auch

top

Arbeitsweise

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 ThreadsPerChild-Direktive angegeben, sowie einen "Listener-Thread", der auf Verbindungen wartet und diese an einen Server-Thread zur Bearbeitung weiterreicht, sobald sie eintreffen.

Der Apache versucht immer, einen Vorrat von freien 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 StartServers 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 MinSpareThreads und MaxSpareThreads 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 MaxClients festgelegt. Die maximale Anzahl der aktiven Kindprozesse ergibt sich aus MaxClients dividiert durch ThreadsPerChild.

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. ServerLimit stellt die obere Grenze fÝr die Anzahl der aktiven Kindprozesse dar und muss grÆúer oder gleich dem Quotienten aus MaxClients und ThreadsPerChild sein. ThreadLimit ist die obere Grenze fÝr die Anzahl der Server-Threads und muss grÆúer oder gleich ThreadsPerChild sein. Sofern fÝr diese Direktiven keine Voreinstellungen verwendet werden, sollten sie vor allen anderen worker-Direktiven platziert werden.

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 MaxClients solcher Prozesse auftreten. Dieses Verhalten kÆnnen Sie vermeiden, indem Sie die Terminierung einzelner Kindprozesse wie folgt abschalten:

Eine typische Konfiguration der Prozess-Thread-Steuerung fÝr das MPM worker kÆnnte wie folgt aussehen:

ServerLimit 16
StartServers 2
MaxClients 150
MinSpareThreads 25
MaxSpareThreads 75
ThreadsPerChild 25

WÄhrend der Elternprozess unter Unix normalerweise als root gestartet wird, um sich an Port 80 binden zu kÆnnen, werden die Kindprozesse und Threads unter einem weniger privilegierten Benutzer gestartet. Die Direktiven User und Group 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 suexec verwendet wird, legen diese Direktiven auch die Privilegien fest, die von CGI-Skripts geerbt werden.

MaxRequestsPerChild bestimmt, wie hÄufig der Server Prozesse erneuert, indem er alte beendet und neue startet.

VerfÝgbare Sprachen:  de  |  en  |  es  |  ja