Перенаправление прокси Nginx на 8443 /

0

В настоящее время мы используем SSL на нашем сервере Tomcat. но из-за необходимости размещать URL-адрес в полном объеме это приносит боль. https: // tomcat: 8443 / SubDomain это действительно смутило некоторых из наших менее технических конечных пользователей, которые сообщают, что страница отчетов не загружается.

В свете этого я надеялся использовать Nginx для перенаправления с порта 80 на 8443 на нашем сервере Tomcat, поскольку SSL находится на Tomcat, и Nginx не нужно обрабатывать SSL. в настоящее время он просто отображает страницу сервера Nginx по умолчанию

upstream tomcat {
    server 127.0.0.1:8443;
    }

    server {
        listen       80;
        server_name  localhost;

        #charset koi8-r;

        #access_log  logs/host.access.log  main;

        location /subdomain/ {
            proxy_pass http://tomcat;
            proxy_set_header Host $host;
            proxy_set_header X-Real-IP $remote_addr;

        }

        #error_page  404              /404.html;

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

        # proxy the PHP scripts to Apache listening on 127.0.0.1:80
        #
        #location ~ \.php$ {
        #    proxy_pass   http://127.0.0.1;
        #}

        # pass the PHP scripts to FastCGI server listening on 127.0.0.1:9000
        #
        #location ~ \.php$ {
        #    root           html;
        #    fastcgi_pass   127.0.0.1:9000;
        #    fastcgi_index  index.php;
        #    fastcgi_param  SCRIPT_FILENAME  /scripts$fastcgi_script_name;
        #    include        fastcgi_params;
        #}

        # deny access to .htaccess files, if Apache's document root
        # concurs with nginx's one
        #
        #location ~ /\.ht {
        #    deny  all;
        #}
    }
Дейв
источник

Ответы:

1

так как SSL на Tomcat, Nginx не нужно обрабатывать SSL

Нет, еще есть. SSL / TLS не «передает» через обратный прокси; это хоп за хопом. Таким образом , даже несмотря на то, что Nginx<->Tomcatподключение защищено с использованием TLS, то user<->Nginxсоединение не - если не включить SSL / TLS в самой Nginx.

(Хотя ваша конфигурация не указывает Nginx использовать TLS для подключения Tomcat. Указания порта недостаточно; вам все равно нужно его использовать proxy_pass https://<backend>.)

в настоящее время он просто отображает страницу сервера Nginx по умолчанию

Это ожидаемо, потому что ваша конфигурация не проксирует все пути; это только прокси URL, начиная с http://<nginx>/subdomain/.

grawity
источник