1<?xml version="1.0" encoding="UTF-8"?>
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="ja" xml:lang="ja"><head><!--
4        XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX
5              This file is generated from xml source: DO NOT EDIT
6        XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX
7      -->
8<title>prefork - Apache HTTP サーバ</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" /><link rel="stylesheet" type="text/css" href="/style/css/prettify.css" />
12<script src="/style/scripts/prettify.min.js" type="text/javascript">
13</script>
14
15<link href="/images/favicon.ico" rel="shortcut icon" /></head>
16<body>
17<div id="page-header">
18<p class="menu"><a href="/mod/">モジュール</a> | <a href="/mod/directives.html">ディレクティブ</a> | <a href="http://wiki.apache.org/httpd/FAQ">FAQ</a> | <a href="/glossary.html">用語</a> | <a href="/sitemap.html">サイトマップ</a></p>
19<p class="apache">Apache HTTP サーバ バージョン 2.4</p>
20<img alt="" src="/images/feather.gif" /></div>
21<div class="up"><a href="./"><img title="&lt;-" alt="&lt;-" src="/images/left.gif" /></a></div>
22<div id="path">
23<a href="http://www.apache.org/">Apache</a> &gt; <a href="http://httpd.apache.org/">HTTP サーバ</a> &gt; <a href="http://httpd.apache.org/docs/">ドキュメンテーション</a> &gt; <a href="../">バージョン 2.4</a> &gt; <a href="./">モジュール</a></div>
24<div id="page-content">
25<div id="preamble"><h1>Apache MPM prefork</h1>
26<div class="toplang">
27<p><span>翻訳済み言語: </span><a href="/de/mod/prefork.html" hreflang="de" rel="alternate" title="Deutsch">&nbsp;de&nbsp;</a> |
28<a href="/en/mod/prefork.html" hreflang="en" rel="alternate" title="English">&nbsp;en&nbsp;</a> |
29<a href="/fr/mod/prefork.html" hreflang="fr" rel="alternate" title="Français">&nbsp;fr&nbsp;</a> |
30<a href="/ja/mod/prefork.html" title="Japanese">&nbsp;ja&nbsp;</a> |
31<a href="/tr/mod/prefork.html" hreflang="tr" rel="alternate" title="Türkçe">&nbsp;tr&nbsp;</a></p>
32</div>
33<div class="outofdate">この日本語訳はすでに古くなっている
34            可能性があります。
35            最近更新された内容を見るには英語版をご覧下さい。
36        </div>
37<table class="module"><tr><th><a href="module-dict.html#Description">説明:</a></th><td>スレッドを使わず、先行して fork を行なうウェブサーバを実装
38</td></tr>
39<tr><th><a href="module-dict.html#Status">ステータス:</a></th><td>MPM</td></tr>
40<tr><th><a href="module-dict.html#ModuleIdentifier">モジュール識別子:</a></th><td>mpm_prefork_module</td></tr>
41<tr><th><a href="module-dict.html#SourceFile">ソースファイル:</a></th><td>prefork.c</td></tr></table>
42<h3>概要</h3>
43
44    <p>このマルチプロセッシングモジュール (MPM) は、
45    Unix 上での Apache 1.3 のデフォルトの挙動と非常によく似た方法で
46    リクエストを処理する、スレッドを使わず、先行して fork を行なう
47    ウェブサーバを実装しています。
48    スレッドセーフでないライブラリとの互換性をとるために、
49    スレッドを避ける必要のあるサイトでは、このモジュールの使用が適切でしょう。
50    あるリクエストで発生した問題が他のリクエストに影響しないように、
51    個々のリクエストを単離するのにも、最適な MPM です。</p>
52
53    <p>この MPM は非常に自律的なので、この MPM の設定ディレクティブを
54    調整する必要はほとんどないでしょう。もっとも重要なことは、
55    <code class="directive"><a href="/mod/mpm_common.html#maxclients">MaxClients</a></code>
56    が、予想される同時リクエスト数を十分扱えるぐらいは大きいけれども、
57    全プロセスに十分な物理メモリが確実に行き渡る程度には小さい値にする、
58    ということです。</p>
59
60</div>
61<div id="quickview"><h3 class="directives">ディレクティブ</h3>
62<ul id="toc">
63<li><img alt="" src="/images/right.gif" /> <a href="mpm_common.html#coredumpdirectory">CoreDumpDirectory</a></li>
64<li><img alt="" src="/images/right.gif" /> <a href="mpm_common.html#enableexceptionhook">EnableExceptionHook</a></li>
65<li><img alt="" src="/images/right.gif" /> <a href="mod_unixd.html#group">Group</a></li>
66<li><img alt="" src="/images/right.gif" /> <a href="mpm_common.html#listen">Listen</a></li>
67<li><img alt="" src="/images/right.gif" /> <a href="mpm_common.html#listenbacklog">ListenBacklog</a></li>
68<li><img alt="" src="/images/right.gif" /> <a href="mpm_common.html#maxconnectionsperchild">MaxConnectionsPerChild</a></li>
69<li><img alt="" src="/images/right.gif" /> <a href="mpm_common.html#maxmemfree">MaxMemFree</a></li>
70<li><img alt="" src="/images/right.gif" /> <a href="mpm_common.html#maxrequestworkers">MaxRequestWorkers</a></li>
71<li><img alt="" src="/images/down.gif" /> <a href="#maxspareservers">MaxSpareServers</a></li>
72<li><img alt="" src="/images/down.gif" /> <a href="#minspareservers">MinSpareServers</a></li>
73<li><img alt="" src="/images/right.gif" /> <a href="mpm_common.html#pidfile">PidFile</a></li>
74<li><img alt="" src="/images/right.gif" /> <a href="mpm_common.html#receivebuffersize">ReceiveBufferSize</a></li>
75<li><img alt="" src="/images/right.gif" /> <a href="mpm_common.html#scoreboardfile">ScoreBoardFile</a></li>
76<li><img alt="" src="/images/right.gif" /> <a href="mpm_common.html#sendbuffersize">SendBufferSize</a></li>
77<li><img alt="" src="/images/right.gif" /> <a href="mpm_common.html#serverlimit">ServerLimit</a></li>
78<li><img alt="" src="/images/right.gif" /> <a href="mpm_common.html#startservers">StartServers</a></li>
79<li><img alt="" src="/images/right.gif" /> <a href="mod_unixd.html#user">User</a></li>
80</ul>
81<h3>トピック</h3>
82<ul id="topics">
83<li><img alt="" src="/images/down.gif" /> <a href="#how-it-works">動作方法</a></li>
84</ul><h3>参照</h3>
85<ul class="seealso">
86<li><a href="/bind.html">Apache
87が使用するアドレスとポートの設定</a></li>
88</ul><ul class="seealso"><li><a href="#comments_section">コメント</a></li></ul></div>
89<div class="top"><a href="#page-header"><img alt="top" src="/images/up.gif" /></a></div>
90<div class="section">
91<h2><a name="how-it-works" id="how-it-works">動作方法</a></h2>
92    <p>一つのコントロールプロセスが、
93    コネクションに対して listen して、しかるべき時に応答する
94    子プロセスを起動します。Apache は常に幾つかの<dfn>スペア</dfn>
95    かアイドルなサーバプロセスを維持していて、それらは入ってきた
96    リクエストに応答できるように待機しています。
97    このようにしてクライアントは、リクエストが応答される前に、
98    新しい子プロセスが fork されるのを待たなくてもよいように
99    なっています。</p>
100
101    <p>親プロセスがリクエストに応答するの子プロセスを
102    どのように生成するかは、
103    <code class="directive"><a href="/mod/mpm_common.html#startservers">StartServers</a></code>,
104    <code class="directive"><a href="#minspareservers">MinSpareServers</a></code>,
105    <code class="directive"><a href="#maxspareservers">MaxSpareServers</a></code>,
106    <code class="directive"><a href="/mod/mpm_common.html#maxclients">MaxClients</a></code>
107    で調整します。一般的に、Apache は非常に自律的なので、
108    大抵のサイトではこれらのディレクティブをデフォルト値から調整する
109    必要はないでしょう。
110    同時に 256 を超えるリクエストに応答しないといけないサイトでは、
111    <code class="directive"><a href="/mod/mpm_common.html#maxclients">MaxClients</a></code>
112    を増やす必要があるでしょう。
113    一方、メモリの限られているサイトでは、スラッシング
114    (メモリとディスク間で何度もスワップ) が起こるのを防ぐために
115    <code class="directive"><a href="/mod/mpm_common.html#maxclients">MaxClients</a></code>
116    を減らす必要があるでしょう。プロセス生成のチューニングに関する
117    詳しい情報は、<a href="/misc/perf-tuning.html">性能に関するヒント</a>
118    にあります。</p>
119
120    <p>通常 Unix では親プロセスは 80 番ポートにバインドするために
121    <code>root</code> で起動されますが、子プロセスやスレッドは
122    もっと低い権限のユーザで Apache によって起動されます。
123    <code class="directive"><a href="/mod/mpm_common.html#user">User</a></code> と
124    <code class="directive"><a href="/mod/mpm_common.html#group">Group</a></code>
125    ディレクティブは
126    Apache の子プロセスの権限を設定するのに用いられます。
127    子プロセスはクライアントに送るコンテンツ全てを読めないといけませんが、
128    可能な限り必要最小限の権限のみを持っているようにするべきです。</p>
129
130    <p><code class="directive"><a href="/mod/mpm_common.html#maxrequestsperchild">MaxRequestsPerChild</a></code>
131    は、古いプロセスを停止して新しいプロセスを起動することによって、
132    どの程度の頻度でサーバがプロセスをリサイクルするかを制御します。</p>
133</div>
134<div class="top"><a href="#page-header"><img alt="top" src="/images/up.gif" /></a></div>
135<div class="directive-section"><h2><a name="MaxSpareServers" id="MaxSpareServers">MaxSpareServers</a> <a name="maxspareservers" id="maxspareservers">ディレクティブ</a></h2>
136<table class="directive">
137<tr><th><a href="directive-dict.html#Description">説明:</a></th><td>アイドルな子サーバプロセスの最大個数</td></tr>
138<tr><th><a href="directive-dict.html#Syntax">構文:</a></th><td><code>MaxSpareServers <var>number</var></code></td></tr>
139<tr><th><a href="directive-dict.html#Default">デフォルト:</a></th><td><code>MaxSpareServers 10</code></td></tr>
140<tr><th><a href="directive-dict.html#Context">コンテキスト:</a></th><td>サーバ設定ファイル</td></tr>
141<tr><th><a href="directive-dict.html#Status">ステータス:</a></th><td>MPM</td></tr>
142<tr><th><a href="directive-dict.html#Module">モジュール:</a></th><td>prefork</td></tr>
143</table>
144    <p><code class="directive">MaxSpareServers</code> ディレクティブは、
145    <em>アイドルな</em>子サーバプロセスの希望最大個数を設定します。
146    アイドルプロセスとは、リクエストを扱っていないプロセスです。
147    <code class="directive">MaxSpareServers</code> よりも多い数がアイドルであれば、
148    親プロセスは超過プロセスを kill します。</p>
149
150    <p>非常に混んでいるサイトでのみ、このパラメータをチューニングするべきです。
151    このパラメータを大きくするということは、大抵の場合は悪い発想です。
152    <code class="directive"><a href="#minspareservers">MinSpareServers</a></code>
153    以下に設定した場合、<code class="directive">MinSpareServers</code>
154    <code>+1</code> に自動調整されます。</p>
155
156<h3>参照</h3>
157<ul>
158<li><code class="directive"><a href="#minspareservers">MinSpareServers</a></code></li>
159<li><code class="directive"><a href="/mod/mpm_common.html#startservers">StartServers</a></code></li>
160</ul>
161</div>
162<div class="top"><a href="#page-header"><img alt="top" src="/images/up.gif" /></a></div>
163<div class="directive-section"><h2><a name="MinSpareServers" id="MinSpareServers">MinSpareServers</a> <a name="minspareservers" id="minspareservers">ディレクティブ</a></h2>
164<table class="directive">
165<tr><th><a href="directive-dict.html#Description">説明:</a></th><td>アイドルな子サーバプロセスの最小個数</td></tr>
166<tr><th><a href="directive-dict.html#Syntax">構文:</a></th><td><code>MinSpareServers <var>number</var></code></td></tr>
167<tr><th><a href="directive-dict.html#Default">デフォルト:</a></th><td><code>MinSpareServers 5</code></td></tr>
168<tr><th><a href="directive-dict.html#Context">コンテキスト:</a></th><td>サーバ設定ファイル</td></tr>
169<tr><th><a href="directive-dict.html#Status">ステータス:</a></th><td>MPM</td></tr>
170<tr><th><a href="directive-dict.html#Module">モジュール:</a></th><td>prefork</td></tr>
171</table>
172    <p><code class="directive">MaxSpareServers</code> ディレクティブは、
173    <em>アイドルな</em>子サーバプロセスの希望最小個数を設定します。
174    アイドルプロセスとは、リクエストを扱っていないプロセスです。
175    <code class="directive">MinSpareServers</code> よりも少ない数がアイドルであれば、
176    親プロセスは最高で 1 秒につき 1 個の割合で新しい子プロセスを生成します。</p>
177
178    <p>非常に混んでいるサイトでのみ、このパラメータをチューニングするべきです。
179    このパラメータを大きくするということは、大抵の場合は悪い発想です。</p>
180
181<h3>参照</h3>
182<ul>
183<li><code class="directive"><a href="#maxspareservers">MaxSpareServers</a></code></li>
184<li><code class="directive"><a href="/mod/mpm_common.html#startservers">StartServers</a></code></li>
185</ul>
186</div>
187</div>
188<div class="bottomlang">
189<p><span>翻訳済み言語: </span><a href="/de/mod/prefork.html" hreflang="de" rel="alternate" title="Deutsch">&nbsp;de&nbsp;</a> |
190<a href="/en/mod/prefork.html" hreflang="en" rel="alternate" title="English">&nbsp;en&nbsp;</a> |
191<a href="/fr/mod/prefork.html" hreflang="fr" rel="alternate" title="Français">&nbsp;fr&nbsp;</a> |
192<a href="/ja/mod/prefork.html" title="Japanese">&nbsp;ja&nbsp;</a> |
193<a href="/tr/mod/prefork.html" hreflang="tr" rel="alternate" title="Türkçe">&nbsp;tr&nbsp;</a></p>
194</div><div class="top"><a href="#page-header"><img src="/images/up.gif" alt="top" /></a></div><div class="section"><h2><a id="comments_section" name="comments_section">コメント</a></h2><div class="warning"><strong>Notice:</strong><br />This is not a Q&amp;A section. Comments placed here should be pointed towards suggestions on improving the documentation or server, and may be removed again by our moderators if they are either implemented or considered invalid/off-topic. Questions on how to manage the Apache HTTP Server should be directed at either our IRC channel, #httpd, on Freenode, or sent to our <a href="http://httpd.apache.org/lists.html">mailing lists</a>.</div>
195<script type="text/javascript"><!--//--><![CDATA[//><!--
196var comments_shortname = 'httpd';
197var comments_identifier = 'http://httpd.apache.org/docs/2.4/mod/prefork.html';
198(function(w, d) {
199    if (w.location.hostname.toLowerCase() == "httpd.apache.org") {
200        d.write('<div id="comments_thread"><\/div>');
201        var s = d.createElement('script');
202        s.type = 'text/javascript';
203        s.async = true;
204        s.src = 'https://comments.apache.org/show_comments.lua?site=' + comments_shortname + '&page=' + comments_identifier;
205        (d.getElementsByTagName('head')[0] || d.getElementsByTagName('body')[0]).appendChild(s);
206    }
207    else { 
208        d.write('<div id="comments_thread">Comments are disabled for this page at the moment.<\/div>');
209    }
210})(window, document);
211//--><!]]></script></div><div id="footer">
212<p class="apache">Copyright 2014 The Apache Software Foundation.<br />この文書は <a href="http://www.apache.org/licenses/LICENSE-2.0">Apache License, Version 2.0</a> のライセンスで提供されています。.</p>
213<p class="menu"><a href="/mod/">モジュール</a> | <a href="/mod/directives.html">ディレクティブ</a> | <a href="http://wiki.apache.org/httpd/FAQ">FAQ</a> | <a href="/glossary.html">用語</a> | <a href="/sitemap.html">サイトマップ</a></p></div><script type="text/javascript"><!--//--><![CDATA[//><!--
214if (typeof(prettyPrint) !== 'undefined') {
215    prettyPrint();
216}
217//--><!]]></script>
218</body></html>