web-dev-qa-db-ja.com

nginx書き換えルールで「リダイレクトが多すぎます」エラーが発生する

すべてのドメイン名がwww.example.comに書き換えられ、次の構成を持つように、自分のサイトをターゲットとするドメインURLを書き換えようとしています。

マイサイトブロック

  server {      
        listen       80 default_server;
        listen   [::]:80 default_server ipv6only=on;

            server_name _;
            rewrite ^ $scheme://www.example.com$request_uri permanent;

    location / {

            # Allow for large file uploads
              client_max_body_size 0;

                proxy_http_version 1.1;
                proxy_pass http://mysite;
                proxy_buffering    off;

                proxy_set_header   X-Real-IP $remote_addr;
                proxy_set_header   X-Scheme $scheme;
                proxy_set_header   X-Forwarded-For $proxy_add_x_forwarded_for;
                proxy_set_header   Host $http_Host;
    }
}

Tomcatサーバーブロック

server {
        listen        80;

        root /opt/site2/www;
        index index.html index.htm;

        # Redirecto root requests to Share
        rewrite ^/$ /share;

        location / {
            # First attempt to serve request as file, then
            # as directory, then fall back to displaying a 404.
            try_files $uri $uri/ /index.html;
        }

        # redirect server error pages to the static page /50x.html
        error_page 502 503 504 /maintenance.html;
            location = /maintenance.html {
            root   /opt/site2/www;
        }

        location /share {

            # Allow for large file uploads
            client_max_body_size 0;

            # Proxy all the requests to Tomcat
            proxy_http_version 1.1;
            #proxy_buffering off;
            proxy_pass http://backend;
            proxy_set_header Host $http_Host;
            proxy_set_header X-Real-IP $remote_addr;
            proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
            proxy_set_header X-Forwarded-Host $http_Host;
            proxy_set_header X-Forwarded-Server $Host;
        }

}

サーバーブロックで、「リダイレクトが多すぎます」エラーが発生します。

6
Dark Star1

現在、すべてのリクエストがこのサーバーブロックにヒットします。

server {      
    listen    80 default_server;
    listen    [::]:80 default_server ipv6only=on;

    server_name _; # This doesn't do anything
    rewrite ^ $scheme://www.example.com$request_uri permanent;

    # Rest of file irrelevant
}

理由:どのサーバーブロックにも有効な server_name がないため(したがって、ホスト名が一致することはありません)、これがdefault_serverです。

適切なサーバー名を使用する

したがって、サーバーにヒットするリクエストを常に特定のホスト名にリダイレクトするには、www.example.comのサーバーブロックが明示的にisであることを確認してください。

server {      
    listen    80;
    listen    [::]:80 ipv6only=on;

    server_name www.example.com;

    # Everything else from "Tomcat server block" 
    # or the proxy_pass config as appropriate
}

そして、他のホスト名を含むリクエストをそれにリダイレクトします:

server {      
    listen    80 default_server;
    listen    [::]:80 default_server ipv6only=on;

    return 301 http://www.example.com$request_uri;

    # Nothing else, because it wouldn't do anything
}

上記の注記では、return 301は無条件の書き換えルールよりも優れていると見なされているため、使用されています。

6
AD7six