blob: 559752e76a831e4aa6114dd20a61e7b4e1959e96 (
plain)
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
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
|
<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE manualpage SYSTEM "./style/manualpage.dtd">
<?xml-stylesheet type="text/xsl" href="./style/manual.ja.xsl"?>
<!-- English Revision: 527129:1174747 (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.
-->
<manualpage metafile="install.xml.meta">
<title>コンパイルとインストール</title>
<summary>
<p>この文書で扱う範囲は、Unix や Unix に類似したシステムでの
Apache のコンパイルとインストールです。 Windows における
コンパイルとインストールに関しては「<a
href="platform/windows.html">Microsoft
Windows で Apache を使う</a>」をご覧下さい。
その他のプラットホームに関しては「<a
href="platform/">プラットホーム</a>」をご覧下さい。</p>
<p>Apache 2.0 では他の Open Source プロジェクトと同様、
ビルド環境構築に <code>libtool</code> と <code>autoconf</code>
を使うようになっています。</p>
<p>マイナーバージョンからその次のバージョンにアップグレードする
(2.2.50 から 2.2.51 へ等) 場合は、まず <a href="#upgrading">
アップグレード</a>をご覧下さい。</p>
</summary>
<seealso><a href="programs/configure.html">ソースツリーの設定</a></seealso>
<seealso><a href="invoking.html">Apacheの起動</a></seealso>
<seealso><a href="stopping.html">Apacheの停止と再起動</a></seealso>
<section id="overview"><title>概要 (せっかちな人向け)</title>
<table>
<columnspec><column width=".13"/><column width=".80"/></columnspec>
<tr>
<td><a href="#download">ダウンロード</a></td>
<td><code>$ lynx http://httpd.apache.org/download.cgi</code>
</td>
</tr>
<tr>
<td><a href="#extract">展開</a></td>
<td><code>$ gzip -d httpd-<em>NN</em>.tar.gz<br />
$ tar xvf httpd-<em>NN</em>.tar<br />
$ cd httpd-<em>NN</em></code></td>
</tr>
<tr>
<td><a href="#configure">設定</a></td>
<td><code>$ ./configure --prefix=<em>PREFIX</em></code>
</td>
</tr>
<tr>
<td><a href="#compile">コンパイル</a></td>
<td><code>$ make</code> </td>
</tr>
<tr>
<td><a href="#install">インストール</a></td>
<td><code>$ make install</code> </td>
</tr>
<tr>
<td><a href="#customize">カスタマイズ</a></td>
<td><code>$ vi <em>PREFIX</em>/conf/httpd.conf</code> </td>
</tr>
<tr>
<td><a href="#test">テスト</a></td>
<td><code>$ <em>PREFIX</em>/bin/apachectl -k start</code>
</td>
</tr>
</table>
<p><em>NN</em> は最新のバージョンナンバーに、
<em>PREFIX</em> はインストールするサーバでのファイルシステムのパスに、
置き換えてください。<em>PREFIX</em> を指定しなかった場合は、
デフォルトの <code>/usr/local/apache2</code> になります。</p>
<p>Apache httpd のコンパイルとインストールに必要なものをはじめとして、
コンパイルとインストールについては、次に詳しく記述されています。</p>
</section>
<section id="requirements"><title>必要なもの</title>
<p>Apache のビルドには次のものが必要です:</p>
<dl>
<dt>ディスクスペース</dt>
<dd>ディスクに少なくとも 50 MB の一時的な空き容量があるように
気を付けてください。インストール後は Apache は 10 MB 程度の
ディスクスペースを占めます。実際に必要になるディスクスペースは、
設定オプションやサードパーティー製モジュールをどう選択するかによって
大きく変わるでしょう。</dd>
<dt>ANSI-C コンパイラとビルドシステム</dt>
<dd>ANSI-C コンパイラをインストールしておいて下さい。お薦めは <a
href="http://www.gnu.org/">Free Software Foundation (FSF)</a>
による <a href="http://www.gnu.org/software/gcc/gcc.html">GNU C
compiler (GCC)</a> です。GCC がない場合は、
少なくとも提供されているコンパイラが ANSI 準拠であることを確認しておいて下さい。
それから、変数 <code>PATH</code> には <code>make</code>
といった基本的なビルドツールが含まれている必要があります。</dd>
<dt>時刻を正確にする</dt>
<dd>HTTP プロトコルの要素は日時の時刻で表現されています。ですから、
正確な時刻にシンクロさせる機能をシステムに設定することを吟味してみて下さい。
Network Time Protocol (NTP) をベースとした ntpdate や xntpd プログラムが
この目的によく用いられます。NTP ソフトウェアや公開 NTP
サーバに関する詳細は、<a
href="http://www.ntp.org">NTP ホームページ</a> をご覧下さい。</dd>
<dt><a href="http://www.perl.org/">Perl 5</a>
[オプション]</dt>
<dd>提供されているスクリプト幾つか、例えば <program>apxs</program> や
<program>dbmmanage</program> は
Perl で書かれているので、Perl
5 インタプリタが必要になります (5.003 以降)。
Perl インタプリタを複数インストールしている (たとえば全体のシステムの一部
としてインストールされている Perl 4 と、自分で追加でインストールした
Perl 5 があるなどの) 場合、<code>--with-perl</code> オプション (下記参照)
を使って <program>configure</program> が意図したものを使うように
明示的に指定すると良いでしょう。
<program>configure</program> スクリプトで Perl 5 インタプリタが
見つからない場合は、この影響を受けるサポートスクリプトが使えなくなります。
もちろん、Apache httpd のコンパイルとインストールは問題なく行えます。</dd>
</dl>
</section>
<section id="download"><title>ダウンロード</title>
<p>Apache HTTP サーバは <a
href="http://httpd.apache.org/download.cgi">Apache HTTP
サーバダウンロードサイト</a>からダウンロードできますし、
同じ場所に幾つかのミラーサイトもリストしています。
UNIX に類似するシステムで Apache を使うユーザは、ソースを
ダウンロードしてビルドしたほうが良いでしょう。
ビルドの手順(下記)は簡単ですし、そのおかげでニーズに
見合ったカスタマイズを簡単にできます。
さらに、バイナリのリリースはソースリリースよりも
遅れていることがよくあります。
それでもバイナリをダウンロードしたのであれば、
ディストリビューションの中にある <code>INSSTALL.bindist</code>
ファイルの説明に従ってください。</p>
<p>ダウンロード後、ダウンロードしたものが Apache HTTP
サーバの完全で改竄されていないバージョンであることを
検証することが重要です。これはダウンロードした tarball の PGP 署名を
テストすることによって検証します。
この手順の詳細は <a
href="http://httpd.apache.org/download.cgi#verify">ダウンロード
ページ</a> にあり、さらに詳しい例は <a
href="http://httpd.apache.org/dev/verification.html">PGP の使用
</a> に記載されています。</p>
</section>
<section id="extract"><title>展開</title>
<p>Apache HTTPD の tarball
からソースファイルを展開して取り出すとは、
単なる圧縮の解除と tar の展開です:</p>
<example>
$ gzip -d httpd-<em>NN</em>.tar.gz<br />
$ tar xvf httpd-<em>NN</em>.tar
</example>
<p>配布用のソースコードがある現在いるディレクトリの下に、
新しいディレクトリが作られます。
サーバをコンパイルする段階に進む前に、そのディレクトリに
<code>cd</code> で移動してください。</p>
</section>
<section id="configure"><title>ソースツリーを設定する</title>
<p>次のステップは、あなたのプラットホームと
個人的な要求に合うように Apache
ソースツリーを設定することです。
これは配布ディレクトリのルートディレクトリにある、
<program>configure</program>
スクリプトで行ないます。
(Apache ソースツリーの未リリース
版をダウンロードした開発者は、次のステップに進む前に
<code>autoconf</code> と<code>libtool</code>
をインストールして <code>buildconf</code>
を実行する必要があります。
公式リリースではこの作業は必要ありません。) </p>
<p>デフォルトオプションを使ってソースツリーを全て設定する
のであれば、単純に <code>./configure</code> とタイプしてください。
デフォルトオプションを変更できるように、<program>configure</program>
には様々な変数やコマンドラインオプションが用意されています。</p>
<p>最も重要なオプションは、Apache がこの後でインストールされる位置
<code>--prefix</code> です。Apache は、このインストール位置に
おいて正常に動作するように設定しなければならないからです。
さらに詳細なファイル位置の制御は追加の <a
href="programs/configure.html#installationdirectories">設定オプション
</a> でできます。</p>
<p>この時点で、<a href="mod/">モジュール</a> を有効にしたり
無効にしたりすることで Apache 本体に含まれる <a
href="programs/configure.html#optionalfeatures">機能</a>
を指定できます。Apache 本体にはデフォルトで、モジュールの <a
href="mod/module-dict.html#Status">Base</a> セットが
含まれます。その他のモジュールは
<code>--enable-<var>module</var></code> オプションで
有効になります。ここで <var>module</var> はモジュールの名前で、
つまりそれはモジュールの名前から <code>mod_</code> 文字列を取り除いた後に
アンダースコアをダッシュで置換した文字列です。
これとは別の方法で <code>--enable-<var>module</var>=shared</code>
オプションを使って、モジュールを<a href="dso.html">
シェアードオブジェクト (DSO)</a> -- 実行時にロードしたり
アンロードしたりできる形式 -- としてコンパイルすることもできます。
同様に、<code>--disable-<var>module</var></code> オプションで
Base モジュールを無効化することもできます。
これらのオプションを使っているときに、もし指定したモジュールが存在しなくても
<program>configure</program> は警告を上げることなく、単純にオプションを
無視することに気をつけてください。</p>
<p>上記に加えて、<program>configure</program> スクリプトに、
コンパイラ、ライブラリ、ヘッダファイルの位置を追加情報として渡す
必要がある場合があります。このような場合には、環境変数あるいは
コマンドラインオプションで <program>configure</program> に渡します。
詳細に関しては <program>configure</program> マニュアルページ
をご覧ください。あるいは <code>--help</code> オプションつきで
<program>configure</program> を呼び出してください。</p>
<p>ちょっとどんなことができるかを見せましょう。
ここで典型的な例として、<code>/sw/pkg/apache</code>
というインストールツリーでコンパイラとフラグを指定して、
さらに二つの追加モジュール <module>mod_rewrite</module> と
<module>mod_speling</module> を後で DSO
メカニズムでロードするようにコンパイルしてみます:</p>
<example>
$ CC="pgcc" CFLAGS="-O2" \<br />
./configure --prefix=/sw/pkg/apache \<br />
--enable-rewrite=shared \<br />
--enable-speling=shared
</example>
<p><program>configure</program> を実行したら、システムの機能を
テストしたり、後でサーバをコンパイルするために必要な Makefile
を生成したりするのに数分間かかるでしょう。</p>
<p>個々の <program>configure</program> オプションの詳細に関しては
<program>configure</program> マニュアルページ
をご覧ください。</p>
</section>
<section id="compile"><title>ビルド</title>
<p>これで Apache の様々なパーツをビルドすることができます。
次のコマンドを単純に実行するだけです:</p>
<example>$ make</example>
<p>基本的な設定をするのに数分かかりますが、
あらかじめご了承ください。
また、時間はハードウェアや有効にしたモジュールの数に
大きく依存するでしょう。</p>
</section>
<section id="install"><title>インストール</title>
<p>さて、設定したインストール <em>PREFIX</em>
(前述の <code>--prefix</code> オプションを参照)
以下にパッケージをインストールする段階になりました。
次のコマンドを実行してください:</p>
<example>$ make install</example>
<p>通常 <em>PREFIX</em> は書き込みパーミッションが制限されている
ディレクトリになっているので、このステップは通常は
ルート権限が必要です。</p>
<p>アップグレードする場合は、インストールでは設定ファイルや
ドキュメントファイルの上書きは行いません。</p>
</section>
<section id="customize"><title>カスタマイズ</title>
<p>次に <code><em>PREFIX</em>/conf/</code> 以下にある <a
href="configuring.html">設定ファイル</a>を編集して、
Apache HTTP サーバをカスタマイズします。</p>
<example>$ vi <em>PREFIX</em>/conf/httpd.conf</example>
<p><code><em>PREFIX</em>/docs/manual/</code> や
<a href="./">docs/manual/</a> にある Apache マニュアルをざっと見てください。
または、<a
href="http://httpd.apache.org/docs/&httpd.docs;/"
>http://httpd.apache.org/docs/&httpd.docs;/</a>
にあるマニュアル最新版、<a
href="mod/directives.html">設定ディレクティブ</a>に当たってみてください。</p>
</section>
<section id="test"><title>テスト</title>
<p>次のコマンドを実行して Apache HTTP サーバを<a
href="invoking.html">開始</a>できます:</p>
<example>$ <em>PREFIX</em>/bin/apachectl -k start</example>
<p>URL <code>http://localhost/</code> を通して最初のドキュメントに対する
リクエストを発行する事ができるはずです。これで見える
ウェブページは <directive module="core">DocumentRoot</directive>
以下に置かれたもので、通常は
<code><em>PREFIX</em>/htdocs/</code> でしょう。
サーバを再び<a href="stopping.html">停止</a>するには、
次のコマンドを実行します:</p>
<example>$ <em>PREFIX</em>/bin/apachectl -k stop</example>
</section>
<section id="upgrading"><title>アップグレード</title>
<p>アップグレードでまず行なうべきことは、リリースアナウンスと
ソースディストリビューションに入っている <code>CHANGES</code> を読んで、
自身のサイトに対して影響を及ぼす変更点を探すことです。
メジャーリリース間の変更をする場合 (例えば 1.3 から 2.0 へ、2.0 から 2.2 へ)
は、コンパイル時や実行時の設定に大きな差異があるでしょうから、
手動の調整が必要になるでしょう。モジュールも全て、API
の変更に合わせるためにアップグレードが必要になるでしょう。</p>
<p>マイナーバージョンから次のバージョンにアップグレードする場合
(例えば 2.2.55 から 2.2.57 へ) は、もっと簡単です。
<code>make install</code> を実行しても今あるドキュメント、
ログファイル、設定ファイルは上書きされません。
さらに、マイナーバージョン間では <program>configure</program> オプション、
実行時の設定、モジュール API に不整合が起こらないように、
開発者は最大限の努力をしています。
大抵の場合、同一の <program>configure</program> コマンドライン、
同一の設定ファイル、モジュール全てが正常に動作するはずです。</p>
<p>マイナーバージョンでアップグレードする場合は、
既にインストールされているサーバの <code>build</code> ディレクトリ内か、
以前インストールに使ったソースコードツリーの最上位ディレクトリ内にある、
<code>config.nice</code> ファイルを探してください。
このファイルにはソースツリーを設定した時に使った
<program>configure</program> コマンドラインが、そのまま入っています。
次のバージョンにアップグレードする場合は <code>config.nice</code>
ファイルを新しいバージョンのソースツリーにコピーし、
必要であればそれを編集した後に、次のように実行します。</p>
<example>
$ ./config.nice<br />
$ make<br />
$ make install<br />
$ <em>PREFIX</em>/bin/apachectl -k graceful-stop<br />
$ <em>PREFIX</em>/bin/apachectl -k start<br />
</example>
<note type="warning">新しいバージョンを使用する場合は、
実際に運用を始める前に、必ず自分用の環境でテストすべきです。
最終的にアップグレードする前に、非互換性がないかをテストするために、
例えば、異なる <code>--prefix</code> と異なるポート (<directive
module="mpm_common">Listen</directive> ディレクティブで設定します)
を使用することで、古いバージョンに影響を与えずに新しいバージョンを
インストールし、実行できます。</note>
<p>もとの <program>configure</program> に追加する形で、
追加の引数を <code>config.nice</code> に渡すこともできます:</p>
<example>
$ ./config.nice --prefix=/home/test/apache --with-port=90
</example>
</section>
</manualpage>
|