⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 worker.xml.de

📁 Apache HTTP Server 是一个功能强大的灵活的与HTTP/1.1相兼容的web服务器.这里给出的是Apache HTTP服务器的源码。
💻 DE
字号:
<?xml version="1.0"?><!DOCTYPE modulesynopsis SYSTEM "../style/modulesynopsis.dtd"><?xml-stylesheet type="text/xsl" href="../style/manual.de.xsl"?><!-- English Revision: 151405 --><!-- Copyright 2003-2004 The Apache Software Foundation Licensed 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&uuml;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&uuml;tzung. Durch die Verwendung    von Threads f&uuml;r die Bedienung von Anfragen ist er in der Lage,    eine gro&szlig;e Anzahl von Anfragen mit weniger Systemressourcen als    ein Prozess-basierter Server zu bedienen. Er beh&auml;lt jedoch viel von    der Stabilit&auml;t eines Prozess-basierten Servers bei, indem er    mehrere Prozesse verf&uuml;gbar h&auml;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&ouml;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&uuml;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&auml;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&auml;hrend des Betriebes, berechnet der Apache die Gesamtzahl    der unbesch&auml;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 &auml;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&uuml;r die Anzahl der aktiven    Kindprozesse fest und k&ouml;nnen nur ge&auml;ndert werden, indem der Server    komplett gestoppt und dann wieder neu gestartet wird. <directive    module="mpm_common">ServerLimit</directive> stellt die obere Grenze f&uuml;r    die Anzahl der aktiven Kindprozesse dar und muss gr&ouml;&szlig;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&uuml;r    die Anzahl der Server-Threads und muss gr&ouml;&szlig;er oder gleich    <directive module="mpm_common">ThreadsPerChild</directive> sein. Sofern f&uuml;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&ouml;glicherweise noch    zus&auml;tzliche Kindprozesse, welche gerade beendet werden, wo allerdings    zumindest noch ein Server-Thread eine existierende Verbindung bearbeitet.    Obwohl die tats&auml;chlich zu erwartende Anzahl deutlich kleiner ist,    k&ouml;nnen bis zu <directive module="mpm_common">MaxClients</directive>    solcher Prozesse auftreten. Dieses Verhalten k&ouml;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&uuml;r    das MPM <module>worker</module> k&ouml;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&auml;hrend der Elternprozess unter Unix normalerweise als    <code>root</code> gestartet wird, um sich an Port 80 binden zu k&ouml;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&uuml;ssen in der Lage sein, alle Inhalte zu lesen, die sie ausliefern    sollen, sollten dar&uuml;ber hinaus jedoch so wenig wie m&ouml;glich Rechte    besitzen. Zus&auml;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&auml;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>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>User</name></directivesynopsis></modulesynopsis>

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -