Назад | Перейти на главную страницу

Ошибка «Слишком много перенаправлений» с правилом перезаписи nginx

Я пытаюсь переписать URL-адрес домена, предназначенный для моего сайта, так, чтобы все доменные имена были переписаны на www.example.com и имели следующую конфигурацию:

блок mysite

  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;
        }

}

в блоке сервера, но я получаю сообщение об ошибке «слишком много перенаправлений».

Прямо сейчас любые запросы будут попадать в этот серверный блок:

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
}

Потому что: ни один серверный блок не имеет действительного название сервера (поэтому совпадения имени хоста никогда не будет), и это default_server.

Используйте соответствующие имена серверов

Поэтому, чтобы всегда перенаправлять запросы, попадающие на сервер, на заданное имя хоста, убедитесь, что является серверный блок специально для www.example.com:

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 используется, поскольку считается лучшей практикой, чем правило безусловной перезаписи.