【问题标题】:SocketIO Connection Error with NodeJS and NginXNodeJS 和 NginX 的 SocketIO 连接错误
【发布时间】:2015-06-28 00:16:33
【问题描述】:

当我尝试使用使用 nginx 的 nodejs 应用程序时,我收到以下错误:

    2015/04/20 22:34:08 [error] 29607#0: *1 connect() failed (111: Connection 
    refused) while connecting to upstream, client: myipaddress, server: 
    mydomain, request: "GET /socket.io/?EIO=3&transport=polling&
    t=1429583647703-9 HTTP/1.1", upstream: "http://127.0.0.1:3000    /socket.io
    /?EIO=3&transport=polling&t=1429583647703-9", host: "mydomain", 
    referrer: "http://mydomain"

我的 nginx sites-available/default 文件如下:

  server {
       listen 80;
       server_name mydomain;
       return 301 https://$server_name$request_uri;
    }

server {
    listen 443 ssl;
    server_name mydomain.com;
    ssl on;
    ssl_certificate /path/to/certificate;
    ssl_certificate_key /path/to/certificate-key;

location / {
    proxy_pass http://127.0.0.1:3000;
    proxy_http_version 1.1;
    proxy_set_header Upgrade $http_upgrade;
    proxy_set_header Connection 'upgrade';
    proxy_set_header Host $host;
    proxy_cache_bypass $http_upgrade;

}
   ssl_prefer_server_ciphers On;
    ssl_protocols TLSv1 TLSv1.1 TLSv1.2;
    ssl_ciphers  ECDH+AESGCM:DH+AESGCM:ECDH+AES256:DH+AES256:ECDH+AES128:DH+AES:ECDH+3DES:DH+3    DES:RSA+AESGCM:RSA+AES:RSA+3DES:!aNULL:!MD5;

}

我正在使用 express,它的 http 服务器配置如下:

app.set('port', process.env.PORT || 3000);
    var server = app.listen(app.get('port'), function() {
    debug('Express server listening on port ' + server.address().port);
});

var io = require("socket.io").listen(server);

任何帮助将不胜感激。

【问题讨论】:

    标签: node.js ssl express nginx socket.io


    【解决方案1】:

    原来我收到这个错误是因为我的 socket.io 代码没有得到正确的身份验证。正确的方法可以在文档here 中看到 像这样:

    io.use(function(socket, next) {
        var handshakeData = socket.request;
        // make sure the handshake data looks good as before
        // if error do this:
        // next(new Error('not authorized');
            // else just call next
            next();
    });
    
    猜你喜欢
    • 2013-07-18
    • 1970-01-01
    • 2013-01-19
    • 2020-04-09
    • 1970-01-01
    • 2020-04-15
    • 2014-04-28
    • 2012-07-14
    • 1970-01-01
    相关资源
    最近更新 更多