Skip to content

HTTPS clone URL

Subversion checkout URL

You can clone with HTTPS or Subversion.

Download ZIP
tree: 8d89273e47
Fetching contributors…

Cannot retrieve contributors at this time

354 lines (279 sloc) 13.41 kb
<?xml version='1.0' encoding='EUC-KR' ?>
<!DOCTYPE manualpage SYSTEM "./style/manualpage.dtd">
<?xml-stylesheet type="text/xsl" href="./style/manual.ko.xsl"?>
<!-- English Revision: 105989:1387657 (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>이 문서는 유닉스와 유닉스류 시스템에서 아파치를 컴파일하고
설치하는 것만을 다룬다. 윈도우즈에서 컴파일하고 설치하는 방법은
<a href="platform/windows.html">마이크로소프트 윈도우즈에서
아파치 사용</a>을 참고하라. 다른 플래폼에 대해서는 <a
href="platform/">플래폼</a> 문서를 참고하라.</p>
<p>아파치 2.0의 구성과 설치 환경은 1.3과 매우 다르다.
아파치 1.3은 쉬운 설치를 위해 자체 스크립트를 사용했다.
아파치 2.0은 이제 다른 여러 오픈소스 프로젝트와 비슷한 환경을
만들기위해 <code>libtool</code>과 <code>autoconf</code>를
사용한다.</p>
<p>만약 작은 버전을 한단계 업그레이드한다면 (예를 들어,
2.0.50에서 2.0.51), <a href="#upgrading">업그레이드</a>
장으로 바로 가길 바란다.</p>
</summary>
<seealso><a href="programs/configure.html">소스 트리 구성</a></seealso>
<seealso><a href="invoking.html">아파치 시작</a></seealso>
<seealso><a href="stopping.html">아파치 중단과 재시작</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-2_1_<em>NN</em>.tar.gz<br />
$ tar xvf httpd-2_1_<em>NN</em>.tar</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 start</code>
</td>
</tr>
</table>
<p><em>NN</em>은 현재 작은 버전 숫자로, <em>PREFIX</em>는
서버가 설치될 파일시스템 경로로 대체해야 한다. <em>PREFIX</em>를
지정하지 않으면 기본값으로 <code>/usr/local/apache2</code>를
사용한다.</p>
<p>아래는 아파치 웹서버를 컴파일하고 설치하기위한 요구사항부터
컴파일과 설치 과정을 각각 자세히 설명한다.</p>
</section>
<section id="requirements"><title>요구사항</title>
<p>아파치를 컴파일하기위해 다음과 같은 것들이 필요하다:</p>
<dl>
<dt>디스크 공간</dt>
<dd>디스크 여유공간이 최소 50 MB 이상인지 확인하라.
설치후 아파치는 약 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>를 추천한다. (버전 2.7.2면 된다.) GCC가
없다면 최소한 사용하는 컴파일러가 ANSI 호환인지 확인하라.
추가로 <code>PATH</code> 환경변수는 <code>make</code>와
같은 기본적인 컴파일 도구를 포함해야 한다.</dd>
<dt>정확한 시간</dt>
<dd>HTTP 프로토콜에는 하루중 시간을 표현하는 부분이 있다. 그래서
이제 시스템의 시간 동기화 기능을 살펴볼 시간이다. 보통
이를 위해 Network Time Protocol (NTP)에 기반한
<code>ntpdate</code>나 <code>xntpd</code>를 사용한다.
NTP 소프트웨어와 공개 시간 서버에 대한 정보는 뉴스그룹
<a href="news:comp.protocols.time.ntp">comp.protocols.time.ntp</a>와
<a href="http://www.ntp.org">NTP 홈페이지</a>를
참고하라.</dd>
<dt><a href="http://www.perl.org/">Perl 5</a>
[선택사항]</dt>
<dd>(Perl로 쓰여진) <a href="programs/apxs.html">apxs</a>나
<a href="programs/dbmmanage.html">dbmmanage</a>와 같은
지원 스크립트를 위해 Perl 5 인터프리터가 필요하다. (버전
5.003 이상이면 된다.) `<code>configure</code>' 스크립트가
이 인터프리터를 찾지 못해도 문제없이 아파치 2.0을
컴파일하고 설치할 수 있다. 다만 지원 스크립트를 사용하지
못할 뿐이다. 여러 Perl 인터프리터가 설치되있다면 (아마도
살때 포함된 Perl 4와 직접 컴파일한 Perl 5)
<code>./configure</code>가 올바른 것을 찾기위해
<code>--with-perl</code> 옵션을 (아래 참고) 사용하길 바란다.</dd>
</dl>
</section>
<section id="download"><title>다운로드</title>
<p>아파치는 여러 미러 목록이 있는 <a
href="http://httpd.apache.org/download.cgi">아파치 웹서버
다운로드 사이트</a>에서 다운로드할 수 있다. 유닉스류 시스템을
사용한다면 소스코드를 다운받아서 컴파일하는 편이 낫다. 쉽게
(아래에서 설명) 컴파일할 수 있고, 자신의 용도에 알맞게 서버를
맞출 수 있다. 또, 최신 버전 바이너리 배포본이 없는 경우도
많다. 바이너리를 다운받는다면 배포본에 있는
<code>INSTALL.bindist</code> 파일의 지시를 따르라.</p>
<p>다운로드후 다운받은 파일이 완전하고
변경되지않은 아파치 웹서버임을 확인하는 것이 중요하다.
PGP 서명을 가지고 다운로드한 타볼(tarball)을 검사하여 확인한다.
자세한 방법은 <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>아파치 웹서버 타볼에서 소스를 푸는 작업은 단순히 압축과
tar를 푸는 것이다:</p>
<example>
$ gzip -d httpd-2_1_<em>NN</em>.tar.gz<br />
$ tar xvf httpd-2_1_<em>NN</em>.tar
</example>
<p>그러면 현재 디렉토리 아래에 배포본의 소스코드를 담은
새로운 디렉토리가 생긴다. 서버를 컴파일하기 전에 그
디렉토리로 <code>cd</code>해야 한다.</p>
</section>
<section id="configure"><title>소스 트리 구성하기</title>
<p>다음 과정은 특정 플래폼과 개인적인 필요에 따라 아파치
소스 트리를 구성하는 일이다. 이를 위해 배포본의 최상위 디렉토리에
있는 <code><a href="programs/configure.html">configure</a></code>
스크립트를 사용한다. (아파치
소스 트리의 CVS 버전을 다운로드한 개발자는 이미
<code>autoconf</code>와 <code>libtool</code>가 설치되있고,
다음 과정으로 넘어가기 전에 <code>buildconf</code>를 실행해야
한다. 이는 정식 버전에서는 필요없다.)</p>
<p>모두 기본 옵션을 사용하여 소스 트리를 구성하려면 간단히
<code>./configure</code>를 입력하면된다. 기본 옵션을 수정하려면
<code>./configure</code>에 여러 변수와 명령행 옵션을 사용한다.</p>
<p>가장 중요한 옵션은 아파치가 정상적으로 작동하기위해 아파치를
구성하고 설치할 장소인 <code>--prefix</code>다. 다른 <a
href="programs/configure.html#installationdirectories">configure
옵션들</a>을 사용하여 파일의 위치를 더 자세히 설정할 수도
있다.</p>
<p><a href="mod/">모듈</a>을 포함하거나 빼서 아파치에 포함할
<a href="programs/configure.html#optionalfeatures">기능</a>을
선택한다. <a href="mod/module-dict.html#Status">Base</a>
상태인 모듈은 기본적으로 아파치에 포함된다. 다른 상태의
모듈은 <code>--enable-<var>module</var></code> 옵션을 사용하여
포함한다. 여기서 <em>module</em>은 모듈 이름에서
<code>mod_</code>를 빼고 밑줄을 빼기기호로 변경한 결과다.
<code>--enable-<var>module</var>=shared</code> 옵션을 사용하면
모듈을 실행중에 포함하거나 뺄 수 있는 <a
href="dso.html">공유객체(shared object, DSO)</a>로 컴파일한다.
또, <code>--disable-<var>module</var></code> 옵션을 사용하여
Base 모듈을 뺄 수 있다. 지정한 모듈이 없어도
<code>configure</code>가 경고하지않고 그냥 무시하기때문에
모듈 이름을 정확히 입력하라.</p>
<p>가끔 <code>configure</code> 스크립트에게 컴파일러,
라이브러리, 헤더파일 등의 위치를 알려줘야 할 경우가 있다.
이 정보는 환경변수나 <code>configure</code>의 명령행 옵션을
사용하여 전달한다. 자세한 내용은 <a
href="programs/configure.html">configure manpage</a>를
참고하라.</p>
<p>여러분이 선택할 수 있는 가능성을 보여주기위해 다음은
특정 컴파일러와 플래그를 사용하고 나중에 DSO로 읽어들일
두 모듈 <module>mod_rewrite</module>와
<module>mod_speling</module>을 추가하여
<code>/sw/pkg/apache</code>에 설치할 아파치를 컴파일하는
전형적인 예이다:</p>
<example>
$ CC="pgcc" CFLAGS="-O2" \<br />
./configure --prefix=/sw/pkg/apache \<br />
--enable-rewrite=shared \<br />
--enable-speling=shared
</example>
<p><code>configure</code>를 실행하면 몇분간 시스템의 기능을
검사하여 나중에 서버를 컴파일할때 사용할 Makefile들을
만든다.</p>
<p><code>configure</code> 옵션들에 대한 자세한 설명은 <a
href="programs/configure.html">configure manpage</a>에 있다.</p>
</section>
<section id="compile"><title>컴파일</title>
<p>이제 다음 명령어 하나로 아파치의 여러 부분을 컴파일할
수 있다:</p>
<example>$ make</example>
<p>여기서 좀 기다려라. 펜티엄 III/리눅스 2.2 시스템에서
기본 구성을 컴파일하는데 약 3분 정도 걸린다. 이 시간은
하드웨어와 포함한 모듈수에 따라 크게 변한다.</p>
</section>
<section id="install"><title>설치</title>
<p>이제 다음 명령어로 패키지를 (위의 <code>--prefix</code>
옵션 참고) 지정한 설치 위치 <em>PREFIX</em>에 설치한다:</p>
<example>$ make install</example>
<p>업그레이드한다면 이 설치 과정이 기존 설정파일이나 문서를
덮어쓰지 않는다.</p>
</section>
<section id="customize"><title>설정</title>
<p>다음으로 <code><em>PREFIX</em>/conf/</code>에 있는
<a href="configuring.html">설정파일</a>을 편집하여 아파치
웹서버를 설정한다.</p>
<example>$ vi <em>PREFIX</em>/conf/httpd.conf</example>
<p>사용가능한 <a href="mod/directives.html">설정 지시어</a>에
대한 완전한 설명과 이 문서의 가장 최근 판은 <a
href="./">docs/manual/</a>이나 <a
href="http://httpd.apache.org/docs/&httpd.docs;/"
>http://httpd.apache.org/docs/&httpd.docs;/</a>에 있는 아파치 설명서를
참고하라.</p>
</section>
<section id="test"><title>검사</title>
<p>이제 다음과 같이 아파치 웹서버를 <a
href="invoking.html">시작</a>할 수 있다:</p>
<example>$ <em>PREFIX</em>/bin/apachectl start</example>
<p>그리고 URL <code>http://localhost/</code>로 첫 문서를
요청한다. 보게될 웹페이지는 아마도
<code><em>PREFIX</em>/htdocs/</code>일 <directive
module="core">DocumentRoot</directive> 아래에 있다. 그리고
다음 명령어로 다시 서버를 <a href="stopping.html">중단</a>한다:</p>
<example>$ <em>PREFIX</em>/bin/apachectl stop</example>
</section>
<section id="upgrading"><title>업그레이드</title>
<p>업그레이드한다면 먼저 사이트에 영향을 줄 수 있는 변화가
있는지 알아보기위해 발표문과 소스 배포본의 <code>CHANGES</code>
파일을 읽는다. (예를 들어, 1.3에서 2.0이나 2.0에서 2.2와
같은) 큰 버전이 변한 경우 컴파일 옵션과 설정을 직접 수정해야할
정도의 큰 변화가 있을 것이다. 모든 모듈도 모듈 API의 변화에
알맞게 업그레이드해야 한다.</p>
<p>작은 버전을 한단계 업그레이드하는 것은 (예를 들어,
2.0.55에서 2.0.57) 쉽다. <code>make install</code> 작업은
기존의 문서, 로그파일, 설정파일을 수정하지 않는다. 또,
개발자는 작은 버전간에 <code>configure</code> 옵션, 설정,
모듈 API의 호환성없는 변화를 최대한 막는다. 대부분의 경우
동일한 <code>configure</code> 명령행, 동일한 설정파일을
사용할 수 있고, 모듈들도 모두 계속 동작할 것이다. (이 말은
2.0.41이후 버전에만 해당한다. 이전 버전들에는 호환성없는
변화가 있다.)</p>
<p>이전에 설치했던 소스를 가지고 있다면, 업그레이드가 더
쉬워진다. 이전 소스 최상위에 있는 <code>config.nice</code>
파일에는 소스를 구성할 때 사용했던 <code>configure</code>
명령행 옵션이 그대로 있다. 그래서 다음 버전으로 업그레이드한다면
새로운 버전 소스로 <code>config.nice</code> 파일을 복사하고,
원한다면 조금 수정을 한 후, 다음과 같이 실행한다:</p>
<example>
$ ./config.nice<br />
$ make<br />
$ make install<br />
$ <em>PREFIX</em>/bin/apachectl stop<br />
$ <em>PREFIX</em>/bin/apachectl start<br />
</example>
<note type="warning">새로운 버전을 사용하기 전에 항상 검사해봐야
한다. 예를 들어, 업그레이드를 마치기 전에 호환성 문제가
있는지 알아보기위해 다른 <code>--prefix</code>와 (<directive
module="mpm_common">Listen</directive> 지시어로) 다른 포트를
사용하여 새로운 버전을 설치한후 이전 버전과 같이 실행해볼
수 있다.</note>
</section>
</manualpage>
Jump to Line
Something went wrong with that request. Please try again.