서버 설정 · 3 min read · Feb 01, 2026
Nginx Catch-All Host As Front End To Apache For ISPConfig 2 On CentOS 5
Nginx Catch-All Host As Front End To Apache For ISPConfig 2 On CentOS 5
Nginx (발음: “엔진 엑스”)는 경량의 고성능 웹 서버/리버스 프록시 및 이메일 (IMAP/POP3) 프록시로, BSD 유사 라이센스 하에 라이센스가 부여됩니다. UNIX, GNU/Linux, BSD 변형, Mac OS X, Solaris 및 Microsoft Windows에서 실행됩니다. Apache의 성능도 일반적으로 매우 좋습니다. 그러나 자원이 제한된 환경에서는 Apache가 반드시 최적의 성능이나 자원 활용을 제공하지는 않습니다. Apache의 부담을 줄이는 “모범 사례” 접근 방식 중 하나는 더 가벼운 웹 서버가 사이트의 정적 파일(이미지, 자바스크립트, CSS 등)을 제공하게 하고, 동적 콘텐츠 제공의 무거운 작업은 Apache에 맡기는 것입니다. 이 튜토리얼에서는 CentOS 5.x에서 ISPConfig 2를 위해 Nginx를 Apache의 프론트 엔드로 설정하는 방법을 보여줍니다.
이 방법이 여러분에게 효과적일 것이라는 보장은 하지 않습니다!
ISPConfig 2 구성하기
먼저, ISPConfig 2 구성 파일을 다음과 같이 변경해야 합니다:
cp -v /root/ispconfig/scripts/lib/config.lib.php /root/ispconfig/scripts/lib/config.lib.php.orig
vi /root/ispconfig/scripts/lib/config.lib.php1283번 줄을 찾아 포트 80을 8080으로 변경합니다:
$web_port = ":80";$web_port = ":8080";2088번 및 2089번 줄을 찾아 포트 80을 8080으로 변경합니다:
$test_vhost = "\n".'
ServerName www.test.tld:80
ServerAdmin [email protected]
DocumentRoot /home
'.$web_httpd_include.'
'; $test_vhost = "\n".'
ServerName www.test.tld:8080
ServerAdmin [email protected]
DocumentRoot /home
'.$web_httpd_include.'
';더 간단한 방법을 원하신다면 다음을 사용하세요:
sed -ie 's/:80/:8080/g' /root/ispconfig/scripts/lib/config.lib.phpApache 구성하기
Apache의 기본 리스닝 포트를 80에서 8080으로 변경합니다.
vi /etc/httpd/conf/httpd.confListen 80
UseCanonicalName OffListen 8080
UseCanonicalName OnNginx 설치하기
Nginx 웹 서버를 설치하려면:
yum install httpd-devel pcre perl pcre-devel zlib zlib-devel
cd /tmp
wget http://download.fedora.redhat.com/pub/epel/5/i386/nginx-0.6.39-5.el5.i386.rpm
rpm -ivh nginx-0.6.39-5.el5.i386.rpm참고: 최신 버전의 Nginx를 설치하고 싶다면 이 링크를 확인하세요: CentOS 5.5에서 SSL, PCRE, GeoIP, Zlib, Gzip 및 DAV 지원과 함께 Nginx 설치하기
이제 Nginx를 구성해야 합니다.
vi /etc/nginx/nginx.confuser nginx;
worker_processes 4;
error_log /var/log/nginx/error.log;
pid /var/run/nginx.pid;
#----------------------------------------------------------------------
# Events Module
#
# http://wiki.codemongers.com/NginxEventsModule
#
#----------------------------------------------------------------------
events {
worker_connections 1024;
use epoll;
}
#----------------------------------------------------------------------
# HTTP Core Module
#
# http://wiki.codemongers.com/NginxHttpCoreModule
#
#----------------------------------------------------------------------
http {
include /etc/nginx/mime.types;
default_type application/octet-stream;
log_format main '$remote_addr - $remote_user [$time_local] $request '
"$status" $body_bytes_sent "$http_referer" '
"$http_user_agent" "$http_x_forwarded_for"';
access_log /var/log/nginx/access.log main;
sendfile on;
tcp_nopush on;
tcp_nodelay on;
keepalive_timeout 65;
gzip on;
gzip_vary on;
gzip_comp_level 6;
gzip_types text/plain text/css application/json application/x-javascript text/xml application/xml application/xml+rss text/javascript;
gzip_buffers 16 8k;
gzip_disable "MSIE [1-6].(?!.*SV1)";
#
proxy_temp_path /var/cache/nginx/temp;
proxy_cache_path /var/cache/nginx/cached levels=1:2 keys_zone=global:60m inactive=15m max_size=1G;
proxy_cache_valid 200 302 10m;
proxy_cache_valid 301 1h;
proxy_cache_valid 404 3m;
proxy_cache_use_stale error timeout http_500 http_502 http_503 http_504;
proxy_cache_key "$scheme$host$request_uri $cookie_user";
#
upstream apache {
server PLACE-IP-ADDRESS-OF-YOUR-SERVER-HERE:8080;
}
###########################################################
#
# The default server
#
server {
proxy_cache global;
listen 80;
server_name _;
server_name_in_redirect off;
resolver 127.0.0.1;
server_tokens off;
if ($host ~* ^(www\.)(.+)) {
set $rawdomain $2;
rewrite ^/(.*)$ http://$rawdomain/$1 permanent;
}
client_max_body_size 30m;
client_body_buffer_size 256k;
location / {
if (-d $request_filename) {
rewrite ^/(.+[^/])$ http://$host/$1/ permanent;
}
proxy_pass http://apache;
proxy_redirect off;
proxy_pass_header Set-Cookie;
proxy_set_header Host $host;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_connect_timeout 120;
proxy_send_timeout 120;
proxy_read_timeout 120;
proxy_buffer_size 4k;
proxy_buffers 4 32k;
proxy_busy_buffers_size 64k;
root /var/www/www.$host/web;
index index.php index.html index.htm default.htm default.html;
}
error_page 404 /404.html;
location = /404.html {
root /usr/share/nginx/html;
}
# redirect server error pages to the static page /50x.html
#
error_page 500 502 503 504 /50x.html;
location = /50x.html {
root /usr/share/nginx/html;
}
location ~* ^.+\.(jpg|jpeg|gif|png|ico|css|zip|tgz|gz|rar|bz2|doc|xls|exe|pdf|ppt|txt|tar|mid|midi|wav|bmp|rtf|js|swf|flv|mp3)$ {
root /var/www/www.$host/web;
access_log off;
proxy_cache_valid 200 10h;
expires 3d;
}
}
include /etc/nginx/conf.d/*.conf;
}
중요한 참고 사항: 이 구성 파일에서 Apache 서버의 IP 주소를 잊지 말고 교체하세요.
필요한 서비스 재시작 및 즐기기!
ISPConfig 및 Apache 서비스를 재시작하고 Nginx 서비스를 시작합니다.
service httpd restart
service ispconfig_server restart
service nginx start테스트
먼저, 가상 호스트 ISPConfig 파일을 확인합니다:
cat /etc/httpd/conf/vhosts/Vhosts_ispconfig.conf다음과 같아야 합니다:
######################################
# Vhost: www.example.com:8080
######################################
#
#
ServerName www.example.com:8080
ServerAdmin [email protected]
DocumentRoot /var/www/web100/web
...
둘째, Nginx 로그 및 오류 파일을 확인합니다.
tail -f /var/log/nginx/access.log
tail -f /var/log/nginx/error.log필요한 경우 서버를 재시작하세요.
새 게시물을 받은 편지함에서 받기
스팸은 없습니다. 언제든지 구독 해지 가능합니다.