Nginx反向代理到另一个提供静态文件的Nginx服务器

我有一台Nginx服务器托管一个Web应用程序,当直接访问该应用程序时可以正常工作.其配置如下

server {
    listen 8000 default_server;

    listen [::]:8000 default_server ipv6only=on;

    root /data/www/ ;
    server_name server1.com;

    location / {
        try_files $uri $uri/ =404;
    }

    location /app/ {

    }   
}

现在我必须从另一台Nginx服务器提供此应用程序,所以我设置了如下的反向代理

server {
    listen 80 default_server;

    listen [::]:80 default_server ipv6only=on;

    root /data/www/ ;
    server_name server2.com;

    location / {
        try_files $uri $uri/ =404;
    }

    location /app/ {
        proxy_pass http://server1.com:8000/app/;
    }
}   

当我从server2访问应用程序时,出现以下错误,例如当我访问http:server2.com/app/css/app.css时

[error] 6601#0: *1 open() “/data/www/app/css/app.css” Failed (2: No such file or directory)

并且serv er1日志中没有错误.当我将Nginx设置为反向代理到server1时,为什么Nginx在server2中寻找静态文件

ProxyPass /app/ http:server1:8000/app/

ProxyPassReverse /app/ http:server1:8000/app/

我想念什么?

最佳答案
您的regexp位置与您的请求/app/css/app.css相匹配,并拦截来自代理的请求.这就是正则表达式位置的工作方式.为防止这种情况,请在您的应用位置使用^〜修饰符:

location ^~ /app/ {
    proxy_pass ...;
}

这将防止正则表达式位置匹配.

文档:http://nginx.org/r/location

相关文章

Nginx (engine x) 是一个高性能的HTTP和反向代理服务,也是一...
本地项目配置 1 复制 luffy/settings/dev.py为prop.py 修改l...
nginx不仅可以隐藏版本信息,还支持自定义web服务器信息 先看...
一 、此次漏洞分析 1 nginx HTTP/2漏洞 [nginx-announce] ng...
###进入nginx 目录cd /usr/local/nginx###递归显示 2 级目录...
在cmd命令窗口输入下面命令进行查看 tasklist /fi "ima...