我不是nginx管理方面的大专家,我只是一个开发人员。我有两个后端在码头运行。让我给他们起个名字
另外,Nginx还公开了443端口,并安装了letsencrypt证书。我对Nginx的配置是(env变量FQDN类似于example.com)
upstream backend1 {
server backend1:8080;
}
upstream backend2 {
server backend2:8081;
}
server {
listen 443 ssl;
server_name ${FQDN} www.${FQDN};
ssl_certificate /etc/letsencrypt/live/${FQDN}/fullchain.pem;
ssl_certificate_key /etc/letsencrypt/live/${FQDN}/privkey.pem;
ssl_session_cache shared:SSL:1m;
ssl_session_timeout 5m;
ssl_ciphers HIGH:!aNULL:!MD5;
ssl_prefer_server_ciphers on;
if ($server_port = 80) { set $https_redirect 1; }
if ($host ~ '^www\.') { set $https_redirect 1; }
if ($https_redirect = 1) { return 301 https://${FQDN}$request_uri; }
location /path1/ {
proxy_pass http://backend1/;
proxy_redirect ~^/(.*) $scheme://$http_host/path1/$1;
proxy_http_version 1.1;
proxy_pass_header Set-Cookie;
proxy_pass_header Cookie;
proxy_pass_header X-Forwarded-For;
proxy_set_header Upgrade $http_upgrade;
proxy_set_header Connection "upgrade";
proxy_set_header Host $http_host;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forward-For $proxy_add_x_forwarded_for;
proxy_set_header X-Forward-Proto http;
proxy_set_header X-Nginx-Proxy true;
add_header X-Upstream $upstream_addr;
}
location /path2/ {
proxy_pass http://backend2/;
proxy_redirect ~^/(.*) $scheme://$http_host/path2/$1;
proxy_http_version 1.1;
proxy_pass_header Set-Cookie;
proxy_pass_header Cookie;
proxy_pass_header X-Forwarded-For;
proxy_set_header Upgrade $http_upgrade;
proxy_set_header Connection "upgrade";
proxy_set_header Host $http_host;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forward-For $proxy_add_x_forwarded_for;
proxy_set_header X-Forward-Proto http;
proxy_set_header X-Nginx-Proxy true;
add_header X-Upstream $upstream_addr;
}
}
如果我请求https://exapmle.com/path1/
,那么Nginx应该转到http://backend1:8080/
并从该服务器返回响应。问题是backend1 (以及backend2)可以用302响应并重定向到某些路径例如。/login
。Nginx将我的浏览器重定向到https://exapmle.com/login
,但我希望它将我重定向到https://exapmle.com/path1/login
,您能帮帮我吗,并指出我在配置中所犯的错误。我重新提出了所有类似的问题,但没有找到任何解决办法。此外,我还研究了Nginx文档,但也没有找到答案。
我有一行proxy_redirect ~^/(.*) $scheme://$http_host/path1/$1;
,我想它必须做我想做的工作。
顺便说一句,我不能在我的Nginx配置中占据/定位(为根路径创建配置),因为它是为另一个后端服务器保留的。提前谢谢。
发布于 2022-04-06 08:51:34
可能是因为您的配置中拼写错误的X转发头。它应该是X-Forwarded-*
而不是X-Forward-*
。
发布于 2022-07-11 06:07:13
location /path1/ {
proxy_pass http://backend1/;
proxy_redirect default;
proxy_redirect / /path1/;
proxy_redirect http://backend1/ https://exapmle.com/path1/;
proxy_http_version 1.1;
proxy_pass_header Set-Cookie;
proxy_pass_header Cookie;
proxy_pass_header X-Forwarded-For;
proxy_set_header Upgrade $http_upgrade;
proxy_set_header Connection "upgrade";
proxy_set_header Host $http_host;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forward-For $proxy_add_x_forwarded_for;
proxy_set_header X-Forward-Proto http;
proxy_set_header X-Nginx-Proxy true;
add_header X-Upstream $upstream_addr;}
那没什么;
https://serverfault.com/questions/1075078
复制相似问题