用Nodejs通过Nginx反向代理来保护Websockets - 错误301。

问题描述 投票:0回答:1

你好,我之前一直想用Apache做这个,但没有成功。我决定尝试用Nginx来代替。

我正在尝试建立以下功能。

client <-- wss -- > Nginx <-- ws -- > Nodejs

看似简单的事情,然而我却没有得到任何成功。我不断地收到错误301。

我的 客户 方面很简单。

const connection = new WebSocket('wss://' + location.host + '/ws');

服务器端是。

const ws = new WebSocket.Server({port: 8080});

Nginx配置文件是。

server {
    server_name example.com;
    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                                                                                                                                                                  

    location / {                                                                                                                                                                                                                                         
        proxy_pass http://localhost:3000;                                                                                                                                                                                                    
    }

    location /ws {                                                                                                                                                                                                                                       
        proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;                                                                                                                   
        proxy_set_header Host $host;                                                                                                                                                                                                                                                                                                                                                                                                                                                              
        proxy_http_version 1.1; # Needed                                                                                                                                                                                                             
        proxy_set_header Upgrade $http_upgrade; # Needed                                                                                                                                                                                             
        proxy_set_header Connection "upgrade"; # Needed                                                                                                                                                                                                                                                                                                                                                                                                                                           
        proxy_pass http://localhost:3000;
    }
}
server {
     if ($host = example.com) {                                                                                                                                                                                                              
          return 301 https://$host$request_uri;
     } # managed by Certbot

     listen 80;

     server_name example.com;
     return 404; # managed by Certbot
}                                                                                                                                                                                                                  

我看到很多关于websockets配置设置的帖子,我没有的那个配置应该肯定能用。但是,无论我怎么努力,都没有用。

javascript node.js ssl nginx websocket
1个回答
0
投票

我想通了。

问题是,我将 Websocket 设置为 8080 端口,但我的 proxy_pass 设置为 3000 端口。

解决方法是让它们都在同一个端口上。

对于应用程序服务器

const ws = new WebSocket.Server({port: 3001});

并让Nginx在ws下拥有相同的端口。

proxy_pass http://localhost:3001;
© www.soinside.com 2019 - 2024. All rights reserved.