일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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 |
- MySQL
- JavaScript
- smarty
- jQuery
- 한글 깨짐
- 부모창
- php
- 천단위
- Oracle
- SVN
- mariadb
- Selectbox
- TextBox
- i18n
- 확장자
- random
- Python
- RabbitMQ
- replace
- centos
- ubuntu
- docker
- install
- yum
- 일괄변경
- Eclipse
- 문자열자르기
- TPL
- Postfix
- Today
- Total
wilson's story
무한대 2차도메인 생성 (apache + mysql 이용) 본문
무한대 2차도메인 생성 (apache + mysql 이용)
------------------------------------------------
개인적으로, 한대의 서버에 여러 도메인과
각 도메인에 대한 2차 도메인을 회원들에게 서비스하고 있습니다.
허나, 회원들의 요청이 많아지게되자,
named 에 계속 추가하여 named restart 시켜주는 방법, 회원 관리가
적절치 못하다고 생각하였습니다.
이곳저곳 문서를 찾다가
우연히 apache 에서 세팅이 가능하며,
name 서버에 일일이 추가하지 않아도 되기에
저의 성공사례를 올립니다.
저의 경우 1대의 서버에
XXX.co.kr
YYY.co.kr
ZZZ.co.kr 도메인을 운영하고,
각각의 도메인에 2차도메인을 부여하여 운영하고 있습니다.
회원이 많아짐에 따라 mysql을 이용하여 2차도메인 정보를 저장하고 있습니다.
서버설정은 아래와 같습니다.
1. 아파치 세팅
1-1.
아파치는 mod_rewrite 모듈이 탑재되어 있어야 합니다.
아파치의 모듈들이 설치된 디렉토리에 mod_rewrite.so 가 없는 경우.
apache 를 다시 컴파일 합니다.
코드:
env CFLAGS="-DEAPI" \
./configure \
--prefix=/etc/httpd \
--enable-module=so \
--enable-shared=max \
--enable-module=rewrite \
--enable-shared=rewrite
make
make install1-2.
httpd.conf 에서 다음을 확인하고 없으면 추가합니다.
코드:
LoadModule rewrite_module libexec/mod_rewrite.so
AddModule mod_rewrite.c
1-3.
최 하단에 버춸호스트를 다음과 같이 작성합니다.
저의 경우는 3개의 도메인을 사용하는 관계로
아래와 같이 3번을 작성하였습니다.
코드:
NameVirtualHost xxx.xxx.xxx.xxx
<VirtualHost xxx.xxx.xxx>
ServerName XXX.co.kr
ServerAlias *.XXX.co.kr
SetEnv force-no-vary
RewriteEngine on
RedirectMatch permanent ^/~([^/]+)(.*)$ http://$1.XXX.co.kr$2
RewriteCond %{HTTP_HOST} !^www\.XXX\.co\.kr$
RewriteCond %{HTTP_HOST} !^XXX\.co\.kr$
RewriteCond %{REQUEST_URI} !^/~(.+)$
RewriteCond %{HTTP_HOST} ^([^.]+)\.XXX\.co\.kr$
RewriteRule ^(.+) /home/XXX/htdocs/virtual/index.html
CustomLog logs/rewrite_access_log "%{VHOST}e %h %l %u %t \"%r\" %>s %b"
</VirtualHost>
<VirtualHost xxx.xxx.xxx.xxx>
ServerName YYY.co.kr
ServerAlias *.YYY.co.kr
RewriteEngine on
RedirectMatch permanent ^/~([^/]+)(.*)$ http://$1.YYY.co.kr$2
RewriteCond %{HTTP_HOST} !^www\.YYY\.co\.kr$
RewriteCond %{HTTP_HOST} !^YYY\.co\.kr$
RewriteCond %{REQUEST_URI} !^/~(.+)$
RewriteCond %{HTTP_HOST} ^([^.]+)\.YYY\.co\.kr$
RewriteRule ^(.+) /home/XXX/htdocs/virtual/index.html
CustomLog logs/rewrite_access_log "%{VHOST}e %h %l %u %t \"%r\" %>s %b"
</VirtualHost>
<VirtualHost xxx.xxx.xxx.xxx>
ServerName ZZZ.co.kr
ServerAlias *.ZZZ.co.kr
RewriteEngine on
RedirectMatch permanent ^/~([^/]+)(.*)$ http://$1.ZZZ.co.kr$2
RewriteCond %{HTTP_HOST} !^www\.ZZZ\.or\.kr$
RewriteCond %{HTTP_HOST} !^ZZZ\.or\.kr$
RewriteCond %{REQUEST_URI} !^/~(.+)$
RewriteCond %{HTTP_HOST} ^([^.]+)\.ZZZ\.or\.kr$
RewriteRule ^(.+) /home/XXX/htdocs/virtual/index.html
CustomLog logs/rewrite_access_log "%{VHOST}e %h %l %u %t \"%r\" %>s %b"
</VirtualHost>
2-1. named 설정
해당하는 zone 파일에서 호스트 이름에 "*" 문자를 사용합니다. (제일 하단부분에 추가)
코드:
* IN A xxx.xxx.xxx.xxx
3-1. mysql table 생성 - 회원이 2차 도메인을 신청시 DB 저장
코드:
CREATE TABLE forward (
num int(11) NOT NULL auto_increment, // 순번
u_id varchar(20) NOT NULL default '', // 사용자 ID
f_id varchar(20) NOT NULL default '', // 2차 도메인(아이디)
f_domain varchar(20) NOT NULL default '', // 2차 도메인(순수 도메인)
title varchar(200) NOT NULL default '홈페이지에 오신걸 환영합니다',
home varchar(200) NOT NULL default '', // 포워딩 처리될 개인 홈페이지 주소
comment varchar(200) default NULL,
reg_date timestamp(14) NOT NULL,
PRIMARY KEY (num),
KEY IDX_UID (u_id),
KEY IDX_FORW (f_id,f_domain)
) TYPE=MyISAM COMMENT='2차도메인 포워딩 서비스 테이블';
P.S
1)
웹 요청이 있을시에 해당 도메인은 모두
/home/XXX/htdocs/virtual/index.html 페이지를 열게 됩니다.
(아파치 설정 참고)
/home/XXX/htdocs/virtual/index.html 화일은 아래와 같습니다.
PHP코드:
<html>
<head>
<title>::XXX.co.kr:: <?=$id?>.<?=$domain?> :: <?= $title?></title>
<meta http-equiv="Content-Type" content="text/html; charset=euc-kr">
<frameset rows="100%,*" border=0>
<frame src=http://<?=$home?> name=_MAIN_><frame name=NARAE></frameset></head></html>
</body>
</html>
2) /home/XXX/htdocs/virtual/index.html 페이지에서는 다음과 같은 일을 해주어야 합니다.
우선,
test.XXX.co.kr 접속이 요청되면 test 와 XXX.co.kr 를 분리시키고,
회원이 신청한 2차 도메인을 mysql 에서 찾습니다.
정보에 맞는 내용을 mysql 에서
뽑아와서 아래의 index.html 에 적당히 뿌려주면 됩니다.