Nginx反向代理不向上游发送请求

时间:2021-04-15 20:46:56

标签: nginx https reverse-proxy

我正在尝试创建一个 nginx 反向代理来终止我的 java 服务的 https。我的 nginx 服务器块设置如下:

server {
        server_name example.com;

        location / {
                proxy_pass http://localhost:8090$request_uri;
        }

        listen [::]:443 ssl; # managed by Certbot
        listen 443 ssl; # managed by Certbot
        ssl_certificate /etc/letsencrypt/live/example.com/fullchain.pem; # managed by Certbot
        ssl_certificate_key /etc/letsencrypt/live/example.com/privkey.pem; # managed by Certbot
        include /etc/letsencrypt/options-ssl-nginx.conf; # managed by Certbot
        ssl_dhparam /etc/letsencrypt/ssl-dhparams.pem; # managed by Certbot

        return 404;
}

我的要求如下:https://example.com/hello?teststring=test 目前服务器正在返回 nginx 404 页面。我知道它正在进入这个块,因为当我将返回 404 更改为返回 302 https://google.com 时,当我发出请求时,它会在浏览器中转到 google,而不是将测试字符串返回到我的浏览器。

我做错了什么?

1 个答案:

答案 0 :(得分:0)

我意识到我有“返回 404;”在我的块结束时,由于我的块中没有 301 或 302 重定向,因此它将流量发送到我的上游服务器,但随后进入 return 语句,然后无论我的请求的有效性如何,都返回 404。我解决了这个问题,只是删除了“返回 404”。评论我是否应该保留某种 return 语句。