Estou usando nginx1.14.2como um proxy reverso com a seguinte configuração
server {
listen xxxxxxx:80;
server_name xxxxxx;
proxy_intercept_errors on;
location /nodejs {
proxy_pass https://nodejs.org;
proxy_cache cache;
proxy_cache_valid 200 301 302 30d;
proxy_cache_valid 404 1m;
expires 30d;
proxy_ssl_server_name on;
proxy_cache_use_stale error timeout invalid_header updating;
}
}
Estou entendendo502 Bad Gatewayno navegador:insira a descrição da imagem aqui Nos logs de erros do nginx, encontrei a seguinte linha:
2020/12/10 11:23:23 [error] 16462#16462: *1 connect() failed (110: Connection timed out) while connecting to upstream, client: xxxxxxx, server: xxxxxxxx, request: "GET /nodejs HTTP/1.1", upstream: "https://104.20.23.46:443/nodejs", host: "xxxxxxxx"
Mas como existe um proxy no backend, a URL com endereço IP é bloqueada. Você tem uma ideia de como forçar o nginx a usar o nome de domínio no lugar do endereço IP no upstream?
Obrigado.
Editar: adicionei a seguinte linha à configuração do proxy_pass:
rewrite /nodejs/(.*) /dist break;
Agora o log de erros está assim:
2020/12/10 12:22:37 [error] 16541#16541: *1 connect() failed (110: Connection timed out) while connecting to upstream, client: xxxxxxx, server: xxxxxxxx, request: "GET /nodejs HTTP/1.1", upstream: "https://104.20.22.46:443/dist", host: "xxxxxxx"
Responder1
Você precisa desta diretiva: proxy_ssl_server_name on;
O padrão é desativado.
http://nginx.org/en/docs/http/ngx_http_proxy_module.html#proxy_ssl_server_name