Nginx 意外返回 Nodejs API 的 404

Posted

技术标签:

【中文标题】Nginx 意外返回 Nodejs API 的 404【英文标题】:Nginx unexpectedly returns 404 for Nodejs API 【发布时间】:2020-10-19 15:40:02 【问题描述】:

我正在尝试在 Digital Ocean 上使用 nginx 设置 VueJS 前端和 NodeJS api 后端服务器。我在设置 Nginx 以使其正常工作时遇到问题。

详细说明我想要实现的目标:

访问 http://ipaddressordomain/ - 返回 Vuejs 应用程序。 VueJS 应用需要从位于 http://ipaddressordomain/api 的后端发送和拉取数据,Nodejs api 在同一台服务器上的 3333 端口上工作。

实际发生的情况:

访问 http://ipaddressordomain/ - 返回 Vuejs 应用程序没有问题。 VueJS 似乎工作正常。 Vuejs 无法连接到后端 api。通过浏览器或 Postman 访问 http://ipaddressordomain/api 也会返回 404。

配置

NodeJS api routes 可用路由应该是 http://myaddress/api on port 3333:

router.route("/api/:sid").get(getUrlShorten);
router.route("/ai").post(postUrlShorten);

Nginx 配置:

Default server configuration
#
server 
        listen 80 default_server;
        listen [::]:80 default_server;

        # SSL configuration
        #
        # listen 443 ssl default_server;
        # listen [::]:443 ssl default_server;
        #
        # Note: You should disable gzip for SSL traffic.
        # See: https://bugs.debian.org/773332
        #
        # Read up on ssl_ciphers to ensure a secure configuration.
        # See: https://bugs.debian.org/765782
        #
        # Self signed certs generated by the ssl-cert package
        # Don't use them in a production server!
        #
        # include snippets/snakeoil.conf;


        # Add index.php to the list if you are using PHP
        index index.html index.htm index.nginx-debian.html;

        server_name lien.to;
        location / 
                root /var/www/html/liento-fe/dist;
        

        location /api/ 
                proxy_pass http://localhost:3333/;
                # as directory, then fall back to displaying a 404.
                try_files $uri $uri/ =404;
        

        # pass PHP scripts to FastCGI server
        #
        #location ~ \.php$ 
        #       include snippets/fastcgi-php.conf;
        #
        #       # With php-fpm (or other unix sockets):
        #       fastcgi_pass unix:/var/run/php/php7.4-fpm.sock;
        #       # With php-cgi (or other tcp sockets):
        #       fastcgi_pass 127.0.0.1:9000;
        #

        # deny access to .htaccess files, if Apache's document root
        # concurs with nginx's one
        #
         

防火墙(UFW):

Status: active

To                         Action      From
--                         ------      ----
Nginx HTTP                 ALLOW       Anywhere                  
OpenSSH                    ALLOW       Anywhere                  
Nginx HTTP (v6)            ALLOW       Anywhere (v6)             
OpenSSH (v6)               ALLOW       Anywhere (v6)             

还有一个问题:在 DO 上,位置代理地址应该是 localhost 还是 DO 服务器的实际 IP?

接下来我可以尝试什么?我有什么遗漏吗?

【问题讨论】:

【参考方案1】:

尝试删除try_files $uri $uri/ =404;:

location /api/ 
  proxy_pass http://localhost:3333/;

这对我有用:https://github.com/gabrielwillemann/fast-help/blob/master/nginx/sites-avaible-examples.md#for-mutiple-proxies

【讨论】:

谢谢老兄!那行得通,我现在确实收到 502 错误,但会尝试解决该问题。我真的是 nginx 和服务器设置的新手和新手,但至少现在我已经解决了一些问题:)。

以上是关于Nginx 意外返回 Nodejs API 的 404的主要内容,如果未能解决你的问题,请参考以下文章

NodeJS SyntaxError:JSON 中位置 0 的意外标记

jQuery.ajax#get 之后出现意外的令牌冒号 JSON

Nodejs v4.4.0API文档学习简介

NodeJsLinux安装NodeJs并配合Nginx实现反向代理

Graphql API 响应返回意外数据

XAMPP 返回错误“JSON 输入意外结束”