在子位置的 nginx 后面运行 socket.io

Running socket.io behind nginx at a sublocation

本文关键字:运行 socket io nginx 位置      更新时间:2023-09-26

我正在尝试在家中的覆盆子上运行一个快速 socket.io 角度.js应用程序。

Express 和 socket.io 在端口 3001 上运行。在 http://[IP]:3001 处访问应用程序工作正常。我想通过 http://[IP]/ttt 访问该应用程序。

我像这样配置nginx:

location /ttt/ {
    proxy_pass http://localhost:3001/;
}

在服务器上,我运行以下代码行:

var express = require('express');
var app = express();
var http = require('http').Server(app);
...
app.use(express.static(__dirname + '/public'));
app.use('/node_modules', express.static(__dirname + '/node_modules'));
...
var io = require('socket.io')(http, {path: '/ttt/socket.io'});
...
http.listen(3001, function () {
    console.log('Listening on port 3001');
});

在客户端,我包括这样的 socket.io:

<script src="socket.io/socket.io.js"></script>

并像这样连接:

socket: Socket = io.connect({path: "/ttt/socket.io"});

问题:

我得到了所有资源(html,css,js,包括socket.io.js),但在浏览器日志中我收到错误消息,它无法获得 http://[IP]/socket.io/?EIO=3&transport=polling&t=LNGvDUd,其中t经常变化。

它报告状态 404,很明显,因为 nginx 在/socket.io 时没有响应。

提前感谢!

<小时 />

与 jfriend00 的组合结果:

工作设置如下所示:

nginx(在此处找到有关正确配置的更多详细信息):

location /ttt/ {
        proxy_set_header Upgrade $http_upgrade;
        proxy_set_header Connection "upgrade";
        proxy_http_version 1.1;
        proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
        proxy_set_header Host $host;
        proxy_pass http://localhost:3001/;
    }

表达:

var io = require('socket.io')(http);

客户端(打字稿):

socket: Socket = io({path: "/ttt/socket.io"});
如果我

正确理解您的代理配置,它将在转发到端口 3001 之前从路径中剥离/ttt。 因此,服务器上的 socket.io 初始化不正确。

更改此设置:

var io = require('socket.io')(http, {path: '/ttt/socket.io'});

对此:

var io = require('socket.io')(http);

编辑:

并且,请确保加载到浏览器中的客户端文件实际上是最新编辑的客户端文件。 您可以使用浏览器中的"查看/源"进行检查,以准确查看正在运行的文件。