我想使用nginx反向代理同一主机/端口上的多个Web应用程序,使用不同的路径来区分应用程序。
我的nginx配置如下:
proxy_set_header Host $http_host;
proxy_set_header Upgrade $http_upgrade;
proxy_set_header Connection $proxy_connection;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_set_header X-Forwarded-Proto $proxy_x_forwarded_proto;
proxy_set_header X-Forwarded-Ssl $proxy_x_forwarded_ssl;
proxy_set_header X-Forwarded-Port $proxy_x_forwarded_port;
upstream app1 {
server 192.168.0.1:8080;
}
upstream app2 {
server 192.168.0.2:8080;
}
server {
server_name my-application-server;
listen 80;
location /app1/ {
proxy_pass http://app1/;
}
location /app2/ {
proxy_pass http://app2/;
}
}
这个配置可以正确代理我应用程序中的所有单个页面请求,例如
http://my-application-server/app1/context/login
,但是我的应用程序中的任何超链接都无法使用,因为它们缺少路径中的app1
部分,例如,它们将我引导到http://my-application-server/context/login-success
而不是http://my-application-server/app1/context/login-success
。我尝试添加各种值的
proxy_redirect
和rewrite
,但是无论我做什么都无法使这些链接正确呈现。我的应用程序是在Tomcat中运行的Java Web应用程序,如果有区别的话。 我已经看到其他解决方案,我可以更改我的Web应用程序的上下文路径,但我需要Nginx能够透明地代理请求,而不需要Tomcat配置了解Nginx路径。