| <?xml version="1.0"?> |
| <!DOCTYPE modulesynopsis SYSTEM "../style/modulesynopsis.dtd"> |
| <?xml-stylesheet type="text/xsl" href="../style/manual.en.xsl"?> |
| <!-- $LastChangedRevision$ --> |
| |
| <!-- |
| 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="event.xml.meta"> |
| <name>event</name> |
| <description>An experimental variant of the standard <module>worker</module> |
| MPM</description> |
| <status>MPM</status> |
| <sourcefile>event.c</sourcefile> |
| <identifier>mpm_event_module</identifier> |
| |
| <summary> |
| <note type="warning"><title>Warning</title> |
| <p>This MPM is experimental, so it may or may not work as |
| expected.</p> |
| </note> |
| |
| <p>The <module>event</module> Multi-Processing Module (MPM) is |
| designed to allow more requests to be served simultaneously by |
| passing off some processing work to supporting threads, freeing up |
| the main threads to work on new requests. It is based on the |
| <module>worker</module> MPM, which implements a hybrid |
| multi-process multi-threaded server. Run-time configuration |
| directives are identical to those provided by |
| <module>worker</module>.</p> |
| |
| <p>To use the <module>event</module> MPM, add |
| <code>--with-mpm=event</code> to the <program>configure</program> |
| script's arguments when building the <program>httpd</program>.</p> |
| |
| </summary> |
| |
| <seealso><a href="worker.html">The worker MPM</a></seealso> |
| |
| <section id="how-it-works"><title>How it Works</title> |
| <p>This MPM tries to fix the 'keep alive problem' in HTTP. After a client |
| completes the first request, the client can keep the connection |
| open, and send further requests using the same socket. This can |
| save significant overhead in creating TCP connections. However, |
| Apache traditionally keeps an entire child process/thread waiting |
| for data from the client, which brings its own disadvantages. To |
| solve this problem, this MPM uses a dedicated thread to handle both |
| the Listening sockets, and all sockets that are in a Keep Alive |
| state.</p> |
| |
| <p>The MPM assumes that the underlying <code>apr_pollset</code> |
| implementation is reasonably threadsafe. This enables the MPM to |
| avoid excessive high level locking, or having to wake up the listener |
| thread in order to send it a keep-alive socket. This is currently |
| only compatible with KQueue and EPoll.</p> |
| |
| </section> |
| <section id="requirements"><title>Requirements</title> |
| <p>This MPM depends on <glossary>APR</glossary>'s atomic |
| compare-and-swap operations for thread synchronization. If you are |
| compiling for an x86 target and you don't need to support 386s, or |
| you are compiling for a SPARC and you don't need to run on |
| pre-UltraSPARC chips, add |
| <code>--enable-nonportable-atomics=yes</code> to the |
| <program>configure</program> script's arguments. This will cause |
| APR to implement atomic operations using efficient opcodes not |
| available in older CPUs.</p> |
| |
| <p>This MPM does not perform well on older platforms which lack good |
| threading, but the requirement for EPoll or KQueue makes this |
| moot.</p> |
| |
| <ul> |
| |
| <li>To use this MPM on FreeBSD, FreeBSD 5.3 or higher is recommended. |
| However, it is possible to run this MPM on FreeBSD 5.2.1, if you |
| use <code>libkse</code> (see <code>man libmap.conf</code>).</li> |
| |
| <li>For NetBSD, at least version 2.0 is recommended.</li> |
| |
| <li>For Linux, a 2.6 kernel is recommended. It is also necessary to |
| ensure that your version of <code>glibc</code> has been compiled |
| with support for EPoll.</li> |
| |
| </ul> |
| </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>Listen</name> |
| </directivesynopsis> |
| <directivesynopsis location="mpm_common"><name>ListenBacklog</name> |
| </directivesynopsis> |
| <directivesynopsis location="mpm_common"><name>SendBufferSize</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>PidFile</name> |
| </directivesynopsis> |
| <directivesynopsis location="mpm_common"><name>ScoreBoardFile</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> |