mirror of
https://github.com/apache/httpd.git
synced 2025-06-01 23:21:45 +03:00
git-svn-id: https://svn.apache.org/repos/asf/httpd/httpd/trunk@103107 13f79535-47bb-0310-9956-ffa450edef68
412 lines
14 KiB
XML
412 lines
14 KiB
XML
<?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: 1.5 (outdated: 1.8) -->
|
|
|
|
<!--
|
|
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.
|
|
-->
|
|
|
|
<manualpage metafile="mass.xml.meta">
|
|
<parentdocument href="./">가상호스트</parentdocument>
|
|
<title>대량의 가상호스트를 동적으로 설정하기</title>
|
|
|
|
<summary>
|
|
|
|
<p>이 문서는 아파치 1.3에서 대량의 가상호스트를 효율적으로
|
|
서비스하는 방법을 설명한다. <!--
|
|
|
|
Written by Tony Finch (fanf@demon.net) (dot@dotat.at).
|
|
|
|
Some examples were derived from Ralf S. Engleschall's document
|
|
http://www.engelschall.com/pw/apache/rewriteguide/
|
|
|
|
Some suggestions were made by Brian Behlendorf.
|
|
|
|
-->
|
|
</p>
|
|
|
|
</summary>
|
|
|
|
<section id="motivation"><title>동기</title>
|
|
|
|
<p>당신의 <code>httpd.conf</code>에 다음과 같이 서로 비슷한
|
|
<code><VirtualHost></code> 섹션들을 많이 있다면 여기서
|
|
설명하는 방법이 도움이 될 것이다:</p>
|
|
|
|
<example>
|
|
NameVirtualHost 111.22.33.44<br />
|
|
<VirtualHost 111.22.33.44><br />
|
|
<indent>
|
|
ServerName www.customer-1.com<br />
|
|
DocumentRoot /www/hosts/www.customer-1.com/docs<br />
|
|
ScriptAlias /cgi-bin/ /www/hosts/www.customer-1.com/cgi-bin<br />
|
|
</indent>
|
|
</VirtualHost><br />
|
|
<VirtualHost 111.22.33.44><br />
|
|
<indent>
|
|
ServerName www.customer-2.com<br />
|
|
DocumentRoot /www/hosts/www.customer-2.com/docs<br />
|
|
ScriptAlias /cgi-bin/ /www/hosts/www.customer-2.com/cgi-bin<br />
|
|
</indent>
|
|
</VirtualHost><br />
|
|
# 바보 바보 바보<br />
|
|
<VirtualHost 111.22.33.44><br />
|
|
<indent>
|
|
ServerName www.customer-N.com<br />
|
|
DocumentRoot /www/hosts/www.customer-N.com/docs<br />
|
|
ScriptAlias /cgi-bin/ /www/hosts/www.customer-N.com/cgi-bin<br />
|
|
</indent>
|
|
</VirtualHost>
|
|
</example>
|
|
|
|
<p>기본 개념은 정적인 <code><VirtualHost></code>
|
|
설정 모두를 동적으로 처리하도록 대체하는 것이다.
|
|
그러면 많은 장점이 있다:</p>
|
|
|
|
<ol>
|
|
<li>설정파일이 작아져서 아파치가 빨리 시작하고 메모리를
|
|
적게 사용한다.</li>
|
|
|
|
<li>가상호스트를 추가하기위해 파일시스템에 적당한
|
|
디렉토리를 만들고 DNS에 항목을 추가하기만 하면된다. 즉,
|
|
아파치를 재설정하고 재시작할 필요가 없다.</li>
|
|
</ol>
|
|
|
|
<p>단점은 각 가상호스트별로 다른 로그파일을 사용할 수 없다는
|
|
점이다. 그러나 매우 많은 가상호스트를 사용한다면 파일기술자를
|
|
다 써버리기때문에 서로 다른 로그파일을 사용할 수 없다. 파이프나
|
|
fifo로 로그를 보내고, 받는 편에서 로그를 처리하여 나누는
|
|
방법이 (통계 등을 모을 수도 있다) 더 낫다.</p>
|
|
|
|
</section>
|
|
|
|
<section id="overview"><title>개요</title>
|
|
|
|
<p>가상호스트는 IP 주소와 HTTP 요청의 <code>Host:</code>
|
|
헤더 정보로 정의한다. 기본적으로 대량의
|
|
동적 가상호스트 기술은 자동으로 가상호스트 정보를 요청의
|
|
파일경로에 포함한다. 이는 대부분 <module>mod_vhost_alias</module>를
|
|
사용하여 쉽게 해결할 수 있지만, 아파치 1.3.6 이하를 사용한다면
|
|
<module>mod_rewrite</module>를 사용해야 한다. 이 두 모듈
|
|
모두 기본적으로 서버에 포함되지 않는다. 이 방법을 사용하려면
|
|
아파치를 구성하고 컴파일할때 포함해야 한다.</p>
|
|
|
|
<p>동적 가상호스트를 일반적인 가상호스트처럼 보이게하려면
|
|
여러가지를 `속여야' 한다. 가장 중요한 것은 아파치가 자기참조
|
|
URL 등을 만들때 사용할 서버명이다. 서버명은
|
|
<code>ServerName</code> 지시어로 설정하며, CGI에는
|
|
<code>SERVER_NAME</code> 환경변수로 주어진다. 실행중 실제
|
|
서버명은 <directive
|
|
module="core">UseCanonicalName</directive> 설정에 달렸다.
|
|
<code>UseCanonicalName Off</code>이면 요청의 <code>Host:</code>
|
|
헤더 내용이 서버명이 된다. <code>UseCanonicalName DNS</code>이면
|
|
가상호스트의 IP 주소를 역DNS 검색하여 서버명을 알아낸다.
|
|
전자는 이름기반 동적 가상호스트에서 사용하고, 후자는 IP기반
|
|
가상호스트에서 사용한다. <code>Host:</code> 헤더가 없거나
|
|
DNS 검색이 실패하여 아파치가 서버명을 알아내지 못하면
|
|
<code>ServerName</code>으로 설정한 값을 대신 사용한다.</p>
|
|
|
|
<p>다른 `속일' 것은 (<code>DocumentRoot</code>로 설정하며,
|
|
CGI에는 <code>DOCUMENT_ROOT</code> 환경변수로 주어지는)
|
|
문서루트이다. 일반적인 경우 core 모듈이 이 설정을 사용하여
|
|
URI에 해당하는 파일명을 찾지만, 서버를 동적 가상호스팅을 할때는 다른
|
|
모듈이 (<code>mod_vhost_alias</code>나 <code>mod_rewrite</code>)
|
|
다른 방법으로 이런 작업을 한다. 두 모듈 모두
|
|
<code>DOCUMENT_ROOT</code> 환경변수를 사용하지 않으므로
|
|
CGI나 SSI 문서가 이 값을 사용한다면 잘못된 결과를 얻을 수
|
|
있다.</p>
|
|
|
|
</section>
|
|
|
|
<section id="simple"><title>간단한 동적 가상호스트</title>
|
|
|
|
<p>위 <a href="#motivation">동기</a> 절의 가상호스트
|
|
설정을 <code>mod_vhost_alias</code>를 사용하여 더 일반적으로
|
|
구현했다.</p>
|
|
|
|
<example>
|
|
# Host: 헤더에서 서버명을 알아낸다<br />
|
|
UseCanonicalName Off<br />
|
|
<br />
|
|
# 첫번째 필드를 사용하여 이 로그를 가상호스트별로 나눌 수 있다<br />
|
|
LogFormat "%V %h %l %u %t \"%r\" %s %b" vcommon<br />
|
|
CustomLog logs/access_log vcommon<br />
|
|
<br />
|
|
# 요청을 처리하기위해 파일명에 서버명을 포함한다<br />
|
|
VirtualDocumentRoot /www/hosts/%0/docs<br />
|
|
VirtualScriptAlias /www/hosts/%0/cgi-bin
|
|
</example>
|
|
|
|
<p>이 설정에서 <code>UseCanonicalName Off</code>를
|
|
<code>UseCanonicalName DNS</code>로 변경하기만 하면 IP기반
|
|
가상호스트가 된다. 가상호스트의 IP 주소를 가지고
|
|
파일명에 추가할 서버명을 알 수 있다.</p>
|
|
|
|
</section>
|
|
|
|
<section id="homepages"><title>가상으로 호스트하는 홈페이지 시스템</title>
|
|
|
|
<p>ISP 홈페이지 서버를 위해 위의 설정을 수정했다. 조금 더
|
|
복잡한 설정을 사용하면 <code>www.user.isp.com</code>의 문서를
|
|
<code>/home/user/</code>에 두는 식으로 서버명의 일부를 가지고
|
|
파일명을 만들 수 있다. 이 설정은
|
|
<code>cgi-bin</code>을 각 가상호스트가 따로 가지지않고
|
|
모든 가상호스트가 같이 사용한다.</p>
|
|
|
|
<example>
|
|
# 기본적인 내용은 위와 같다. 그리고<br />
|
|
<br />
|
|
# 파일명에 서버명의 일부를 포함한다<br />
|
|
VirtualDocumentRoot /www/hosts/%2/docs<br />
|
|
<br />
|
|
# 하나의 cgi-bin 디렉토리<br />
|
|
ScriptAlias /cgi-bin/ /www/std-cgi/<br />
|
|
</example>
|
|
|
|
<p><module>mod_vhost_alias</module> 문서에는 더 복잡한
|
|
<code>VirtualDocumentRoot</code> 설정의 예가 있다.</p>
|
|
|
|
</section>
|
|
|
|
<section id="combinations"><title>한 서버에 여러 가상호스트
|
|
시스템 사용하기</title>
|
|
|
|
<p>더 복잡한 설정의 예로 아파치의 일반적인
|
|
<code><VirtualHost></code> 지시어를 사용하여 여러
|
|
가상호스트 설정의 범위를 조절할 수 있다. 예를 들어, 다음과
|
|
같은 설정은 홈페이지 고객에 IP 주소 한개, 상업적인
|
|
고객에게 다른 IP 주소 한개를 부여한다. 물론 이전처럼
|
|
<code><VirtualHost></code> 설정 섹션에 모두 묶을 수도
|
|
있다.</p>
|
|
|
|
<example>
|
|
UseCanonicalName Off<br />
|
|
<br />
|
|
LogFormat "%V %h %l %u %t \"%r\" %s %b" vcommon<br />
|
|
<br />
|
|
<Directory /www/commercial><br />
|
|
<indent>
|
|
Options FollowSymLinks<br />
|
|
AllowOverride All<br />
|
|
</indent>
|
|
</Directory><br />
|
|
<br />
|
|
<Directory /www/homepages><br />
|
|
<indent>
|
|
Options FollowSymLinks<br />
|
|
AllowOverride None<br />
|
|
</indent>
|
|
</Directory><br />
|
|
<br />
|
|
<VirtualHost 111.22.33.44><br />
|
|
<indent>
|
|
ServerName www.commercial.isp.com<br />
|
|
<br />
|
|
CustomLog logs/access_log.commercial vcommon<br />
|
|
<br />
|
|
VirtualDocumentRoot /www/commercial/%0/docs<br />
|
|
VirtualScriptAlias /www/commercial/%0/cgi-bin<br />
|
|
</indent>
|
|
</VirtualHost><br />
|
|
<br />
|
|
<VirtualHost 111.22.33.45><br />
|
|
<indent>
|
|
ServerName www.homepages.isp.com<br />
|
|
<br />
|
|
CustomLog logs/access_log.homepages vcommon<br />
|
|
<br />
|
|
VirtualDocumentRoot /www/homepages/%0/docs<br />
|
|
ScriptAlias /cgi-bin/ /www/std-cgi/<br />
|
|
</indent>
|
|
</VirtualHost>
|
|
</example>
|
|
|
|
</section>
|
|
|
|
<section id="ipbased"><title>더 효율적인 IP기반 가상호스트</title>
|
|
|
|
<p><a href="#simple">첫번째 예</a>에서 나는 설정을 간단히
|
|
IP기반 가상호스트로 바꿀 수 있다고 말했다. 불행히도
|
|
그런 설정은 매 요청마다 DNS를 찾아야하므로 매우 비효율적이다.
|
|
이름대신 IP 주소로 파일시스템을 구성하고 같은 방식으로
|
|
로그를 수정하면 문제를 해결할 수 있다. 아파치는 서버명을
|
|
다룰 필요가 없어지고, DNS 검색도 하지 않게 된다.</p>
|
|
|
|
<example>
|
|
# IP 주소를 역DNS 검색하여 서버명을 알아낸다<br />
|
|
UseCanonicalName DNS<br />
|
|
<br />
|
|
# 로그를 나눌 수 있도록 IP 주소를 포함한다<br />
|
|
LogFormat "%A %h %l %u %t \"%r\" %s %b" vcommon<br />
|
|
CustomLog logs/access_log vcommon<br />
|
|
<br />
|
|
# 파일명에 IP 주소를 포함한다<br />
|
|
VirtualDocumentRootIP /www/hosts/%0/docs<br />
|
|
VirtualScriptAliasIP /www/hosts/%0/cgi-bin<br />
|
|
</example>
|
|
|
|
</section>
|
|
|
|
<section id="oldversion"><title>아파치 이전 버전 사용하기</title>
|
|
|
|
<p>위 예들은 아파치 버전 1.3.6 이후에 포함된
|
|
<code>mod_vhost_alias</code>을 사용한다.
|
|
<code>mod_vhost_alias</code>가 없는 아파치 버전을 사용한다면
|
|
이미 말했듯이 <code>mod_rewrite</code>를 사용하여, 단
|
|
Host:-헤더기반 가상호스트만을, 구현할 수 있다.</p>
|
|
|
|
<p>또 로그에 관하여 주의할 점이 있다. 아파치 1.3.6에서
|
|
로그형식 지시어 <code>%V</code>가 포함되었고, 버전 1.3.0
|
|
- 1.3.3에서 이 기능을 <code>%v</code> 옵션이 대신 했다. 그러나
|
|
버전 1.3.4에는 이런 기능이 없다. 어떤 아파치 버전에서도
|
|
<code>.htaccess</code> 파일에서 <code>UseCanonicalName</code>
|
|
지시어를 사용할 수 있으므로 로그에 이상한 내용이 기록될 수 있다.
|
|
그러므로 가장 좋은 방법은 <code>%{Host}i</code> 지시어를
|
|
사용하여 <code>Host:</code> 헤더를 직접 로그에 남기는 것이다.
|
|
또, 이 방법은 <code>%V</code>는 포함하지않는 <code>:port</code>를
|
|
뒤에 추가할 수 있다.</p>
|
|
|
|
</section>
|
|
|
|
<section id="simple.rewrite"><title><code>mod_rewrite</code>를
|
|
사용한 간단한 동적 가상호스트</title>
|
|
|
|
<p>다음은 <a href="#simple">첫번째 예</a>와 같은 일을 하는
|
|
<code>httpd.conf</code> 예이다. 처음 절반은 첫번째 예와
|
|
거의 비슷하지만, 이전 버전과의 호환성과 <code>mod_rewrite</code>의
|
|
적절한 동작을 위해 수정되었다. 나머지 절반은 실제 작업을
|
|
하는 <code>mod_rewrite</code>를 설정한다.</p>
|
|
|
|
<p>특별히 주의해야 할 사항이 있다. 기본적으로
|
|
<code>mod_rewrite</code>는 (<code>mod_alias</code> 등) 다른
|
|
URI 번역 모듈 이전에 실행된다. 그래서 다른 URI 번역 모듈들과
|
|
같이 동작할 것을 고려하여 <code>mod_rewrite</code>를 설정해야 한다.
|
|
또, 동적 가상호스트에서 <code>ScriptAlias</code>과 같은
|
|
기능을 위해서는 특별한 작업이 필요하다.</p>
|
|
|
|
<example>
|
|
# Host: 헤더에서 서버명을 얻는다<br />
|
|
UseCanonicalName Off<br />
|
|
<br />
|
|
# splittable logs<br />
|
|
LogFormat "%{Host}i %h %l %u %t \"%r\" %s %b" vcommon<br />
|
|
CustomLog logs/access_log vcommon<br />
|
|
<br />
|
|
<Directory /www/hosts><br />
|
|
<indent>
|
|
# ScriptAlias 식으로 CGI 실행을 강제할 수 없기때문에<br />
|
|
# 여기에 ExecCGI를 사용한다<br />
|
|
Options FollowSymLinks ExecCGI<br />
|
|
</indent>
|
|
</Directory><br />
|
|
<br />
|
|
# 이제 어려운 부분이다<br />
|
|
<br />
|
|
RewriteEngine On<br />
|
|
<br />
|
|
# Host: 헤더에서 가져온 서버명에는 대소문자가 뒤섞여있을 수 있다<br />
|
|
RewriteMap lowercase int:tolower<br />
|
|
<br />
|
|
## 일반 문서를 먼저 처리한다:<br />
|
|
# Alias /icons/ 가 동작하도록 - 다른 alias에 대해서도 반복<br />
|
|
RewriteCond %{REQUEST_URI} !^/icons/<br />
|
|
# CGI가 동작하도록<br />
|
|
RewriteCond %{REQUEST_URI} !^/cgi-bin/<br />
|
|
# 특별한 작업<br />
|
|
RewriteRule ^/(.*)$ /www/hosts/${lowercase:%{SERVER_NAME}}/docs/$1<br />
|
|
<br />
|
|
## 이제 CGI를 처리한다 - MIME type을 강제해야 한다<br />
|
|
RewriteCond %{REQUEST_URI} ^/cgi-bin/<br />
|
|
RewriteRule ^/(.*)$ /www/hosts/${lowercase:%{SERVER_NAME}}/cgi-bin/$1 [T=application/x-httpd-cgi]<br />
|
|
<br />
|
|
# 끝!
|
|
</example>
|
|
|
|
</section>
|
|
|
|
<section id="homepages.rewrite"><title><code>mod_rewrite</code>를
|
|
사용한 홈페이지 시스템</title>
|
|
|
|
<p>다음은 <a href="#homepages">두번째 예</a>와 같은 일을
|
|
한다.</p>
|
|
|
|
<example>
|
|
RewriteEngine on<br />
|
|
<br />
|
|
RewriteMap lowercase int:tolower<br />
|
|
<br />
|
|
# CGI가 동작하도록<br />
|
|
RewriteCond %{REQUEST_URI} !^/cgi-bin/<br />
|
|
<br />
|
|
# RewriteRule이 동작하도록 호스트명이 올바른지 검사한다<br />
|
|
RewriteCond ${lowercase:%{SERVER_NAME}} ^www\.[a-z-]+\.isp\.com$<br />
|
|
<br />
|
|
# 가상호스트명을 URI 앞에 붙인다<br />
|
|
# [C]는 이 결과를 가지고 다음 재작성을 수행함을 뜻한다<br />
|
|
RewriteRule ^(.+) ${lowercase:%{SERVER_NAME}}$1 [C]<br />
|
|
<br />
|
|
# 이제 실제 파일명을 만든다<br />
|
|
RewriteRule ^www\.([a-z-]+)\.isp\.com/(.*) /home/$1/$2<br />
|
|
<br />
|
|
# 전체 CGI 디렉토리를 정의한다<br />
|
|
ScriptAlias /cgi-bin/ /www/std-cgi/
|
|
</example>
|
|
|
|
</section>
|
|
|
|
<section id="xtra-conf"><title>별도의 가상호스트 설정파일
|
|
사용하기</title>
|
|
|
|
<p>다음은 <code>mod_rewrite</code>의 고급 기능을 사용하여
|
|
별도의 설정파일을 가지고 가상호스트의 문서루트를 알아낸다.
|
|
더 유연하지만 더 복잡한 설정이 필요하다.</p>
|
|
|
|
<p><code>vhost.map</code> 파일은 다음과 같다:</p>
|
|
|
|
<example>
|
|
www.customer-1.com /www/customers/1<br />
|
|
www.customer-2.com /www/customers/2<br />
|
|
# ...<br />
|
|
www.customer-N.com /www/customers/N<br />
|
|
</example>
|
|
|
|
<p><code>http.conf</code>는 다음과 같다:</p>
|
|
|
|
<example>
|
|
RewriteEngine on<br />
|
|
<br />
|
|
RewriteMap lowercase int:tolower<br />
|
|
<br />
|
|
# 대응파일을 정의한다<br />
|
|
RewriteMap vhost txt:/www/conf/vhost.map<br />
|
|
<br />
|
|
# 위와 같이 alias들을 처리한다<br />
|
|
RewriteCond %{REQUEST_URI} !^/icons/<br />
|
|
RewriteCond %{REQUEST_URI} !^/cgi-bin/<br />
|
|
RewriteCond ${lowercase:%{SERVER_NAME}} ^(.+)$<br />
|
|
# 파일 내용을 가지고 찾는다<br />
|
|
RewriteCond ${vhost:%1} ^(/.*)$<br />
|
|
RewriteRule ^/(.*)$ %1/docs/$1<br />
|
|
<br />
|
|
RewriteCond %{REQUEST_URI} ^/cgi-bin/<br />
|
|
RewriteCond ${lowercase:%{SERVER_NAME}} ^(.+)$<br />
|
|
RewriteCond ${vhost:%1} ^(/.*)$<br />
|
|
RewriteRule ^/(.*)$ %1/cgi-bin/$1
|
|
</example>
|
|
|
|
</section>
|
|
</manualpage>
|