При получении “Слишком многих перенаправлений” ошибка с 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;
    }
}

Блок сервера кота

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
задан 11 December 2014 в 12:42
1 ответ

Сейчас любой и все запросы будут попадать в этот блок сервера:

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
}

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

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

Поэтому, чтобы всегда перенаправлять запросы, попадающие на сервер, на заданное имя хоста, убедитесь, что в есть серверный блок, явно предназначенный для примера 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 используется, так как это считается лучшей практикой, чем безусловное правило перезаписи.

6
ответ дан 3 December 2019 в 00:28

Теги

Похожие вопросы