Ubuntu 22.04
Sponsored Link

Nginx : リバースプロキシの設定2022/05/11

 
Nginx でのリバースプロキシの設定です。
例として、ホスト [www.srv.world] の Nginx サーバーで受けた HTTP/HTTPS アクセスを、バックエンドホスト [node01.srv.world] の Nginx サーバーへ転送するよう設定します。
[1]
[2] Nginx の設定です。
root@www:~#
vi /etc/nginx/sites-available/default
# 内容を以下のように変更
# サーバー名や証明書等は自身の環境に置き換え

server {
        listen      80 default_server;
        listen      [::]:80 default_server;
        listen      443 ssl http2 default_server;
        listen      [::]:443 ssl http2 default_server;
        server_name www.srv.world;

        ssl_certificate "/etc/letsencrypt/live/www.srv.world/fullchain.pem";
        ssl_certificate_key "/etc/letsencrypt/live/www.srv.world/privkey.pem";
        ssl_session_cache shared:SSL:1m;
        ssl_session_timeout  10m;

        proxy_redirect      off;
        proxy_set_header    X-Real-IP $remote_addr;
        proxy_set_header    X-Forwarded-For $proxy_add_x_forwarded_for;
        proxy_set_header    Host $http_host;

        location / {
                proxy_pass http://node01.srv.world/;
        }
}

root@www:~#
systemctl reload nginx

[3] バックエンド Nginx サーバーで X-Forwarded-For ヘッダーをロギングするよう設定しておきます。
root@node01:~#
vi /etc/nginx/nginx.conf
# [http] セクション内に [log_format] 設定を追記

http {
        log_format main '$remote_addr - $remote_user [$time_local] "$request" '
        '$status $body_bytes_sent "$http_referer" '
        '"$http_user_agent" "$http_x_forwarded_for"';

root@node01:~#
vi /etc/nginx/sites-available/default
# [server] セクション内に追記
# [set_real_ip_from] は自身の信頼できる内部ネットワークを指定

server {
        listen 80 default_server;
        listen [::]:80 default_server;
        set_real_ip_from   10.0.0.0/24;
        real_ip_header     X-Forwarded-For;

root@node01:~#
systemctl reload nginx

[4] 任意のクライアントコンピューターからフロントエンドの Nginx サーバーへ HTTP/HTTPS アクセスして動作を確認します。 また、バックエンドの Nginx ログ [/var/log/nginx/access.log] にアクセス元のクライアントホストの IP アドレスがロギングされていることも確認しておくとよいでしょう。
[5]
複数のホスト名宛てのリクエストをプロキシすることも可能です。
例として、[www.srv.world], [rx-7.srv.world], [rx-8.srv.world] は DNS 設定により、同じ IP アドレス (当例では 10.0.0.31) を関連付けており、Nginx が稼働するサーバーは、それらのホスト名宛てのリクエストを全て受け付けることを前提とします。
当例では同じドメイン名を使用していますが、ドメイン名が異なっていても問題ありません。
[www.srv.world] 宛てのリクエストは Nginx のデフォルトサイトへ、
[rx-7.srv.world] 宛てのリクエストは、バックエンドの [rx-7.srv.world (10.0.0.101)] へ、
[rx-8.srv.world] 宛てのリクエストは、バックエンドの [rx-8.srv.world (10.0.0.102)] へ、それぞれ転送するように設定します。
root@www:~#
vi /etc/nginx/sites-available/rx-7.srv.world.conf
# 新規作成

server {
        listen      80;
        listen      [::]:80;
        listen      443 ssl http2;
        listen      [::]:443 ssl http2;
        server_name rx-7.srv.world;

        ssl_certificate "/etc/letsencrypt/live/rx-7.srv.world/fullchain1.pem";
        ssl_certificate_key "/etc/letsencrypt/live/rx-7.srv.world/privkey1.pem";
        ssl_session_cache shared:SSL:1m;
        ssl_session_timeout  10m;

        proxy_redirect      off;
        proxy_set_header    X-Real-IP $remote_addr;
        proxy_set_header    X-Forwarded-For $proxy_add_x_forwarded_for;
        proxy_set_header    Host $http_host;

        location / {
                proxy_pass http://rx-7.srv.world/;
        }
}

root@www:~#
vi /etc/nginx/sites-available/rx-8.srv.world.conf
# 新規作成

server {
        listen      80;
        listen      [::]:80;
        listen      443 ssl http2;
        listen      [::]:443 ssl http2;
        server_name rx-8.srv.world;

        ssl_certificate "/etc/letsencrypt/live/rx-8.srv.world/fullchain1.pem";
        ssl_certificate_key "/etc/letsencrypt/live/rx-8.srv.world/privkey1.pem";
        ssl_session_cache shared:SSL:1m;
        ssl_session_timeout  10m;

        proxy_redirect      off;
        proxy_set_header    X-Real-IP $remote_addr;
        proxy_set_header    X-Forwarded-For $proxy_add_x_forwarded_for;
        proxy_set_header    Host $http_host;

        location / {
                proxy_pass http://rx-8.srv.world/;
        }
}

root@www:~#
cd /etc/nginx/sites-enabled

root@www:/etc/nginx/sites-enabled#
ln -s ../sites-available/rx-7.srv.world.conf ./

root@www:/etc/nginx/sites-enabled#
ln -s ../sites-available/rx-8.srv.world.conf ./

root@www:/etc/nginx/sites-enabled#
systemctl reload nginx

[6] それぞれのホスト名宛てに HTTP アクセスして、以下のようのそれぞれのバックエンドサーバーが正常に応答すれば OK です。
関連コンテンツ