サーバー設定 · 2 min read · Feb 01, 2026

NginxをフロントエンドとしてApacheに接続するためのISPConfig 2の設定 (CentOS 5)

NginxをフロントエンドとしてApacheに接続するためのISPConfig 2の設定 (CentOS 5)

Nginx(発音は「エンジンX」)は、軽量で高性能なWebサーバー/リバースプロキシおよびメール(IMAP/POP3)プロキシで、BSDライクなライセンスの下でライセンスされています。UNIX、GNU/Linux、BSDバリアント、Mac OS X、Solaris、およびMicrosoft Windowsで動作します。Apacheのパフォーマンスも一般的に非常に良好です。しかし、リソースが制約された環境では、Apacheは必ずしも最適なパフォーマンスやリソースの利用を提供するわけではありません。Apacheへの負担を軽減するための「ベストプラクティス」のアプローチの1つは、より軽量なWebサーバーにサイトの静的ファイル(画像、JavaScript、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.php

行番号1283を見つけて、ポート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.php

Apacheの設定

Apacheのデフォルトのリスニングポートを80から8080に変更します。

vi /etc/httpd/conf/httpd.conf
Listen 80
UseCanonicalName Off
Listen 8080
UseCanonicalName On

Nginxのインストール

Nginx Webサーバーをインストールするには:

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.conf
user nginx;
worker_processes 4;
error_log /var/log/nginx/error.log;
pid /var/run/nginx.pid;
#----------------------------------------------------------------------
# イベントモジュール 
#
# http://wiki.codemongers.com/NginxEventsModule
#
#----------------------------------------------------------------------
events {
    worker_connections 1024;
    use epoll;
}
#----------------------------------------------------------------------
# HTTPコアモジュール
#
# 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;
    }
    ###########################################################
    #
    # デフォルトサーバー
    #
    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;
        }
        
        # サーバーエラーページを静的ページ/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

必要に応じてサーバーを再起動します。

Share: X/Twitter LinkedIn

新しい投稿を受信箱で受け取る

スパムはありません。いつでも購読を解除できます。