Flask-SocketIO应用程序继续使用轮询

时间:2018-04-27 12:08:43

标签: python nginx flask-socketio

我有一个用Flask-SocketIO编写的基本websocket服务器应用程序,位于AWS的NGINX后面。我可以使用Web客户端(Chrome和FFox)成功连接到它,但它继续使用轮询而不是Web套接字。测试时,我一遍又一遍地在控制台中看到如下消息:

127.0.0.1 - - [2018-04-27 11:59:43]" GET /socket.io/?token=1234567890qwertyuiop&EIO=3&transport=polling&t=1524830363623-23&sid = c406e264e3ac4a06b22a1b0d4f08cf5d HTTP / 1.1" 200 191 25.966415

经过一些研究,我添加了#34; rememberTransport:false"到客户端连接选项,但没有帮助,所以可能是我的代码或配置有问题。我希望有人能够发现我所犯的明显(noob)错误。

更新29/4/2018

我修改了我的AWS安全组,因此我可以绕过NGINX并直接访问测试WSGI服务器。所以现在我在我的本地PC上使用http://serverIP:5000。我仍然遇到同样的问题,所以它与NGINX配置无关。

我刚刚将示例代码复制到我的RPi3B并在那里运行服务器。我的三星手机浏览器,PC FFox,PC Chrome和RPi Chromium都会导致轮询连接。所以看起来好像是Flask-SocketIO服务器。我的代码很简单,所以可能出错?

我的服务器代码如下:

#!/usr/bin/env python
from flask_socketio import SocketIO, join_room, send, emit, disconnect
from flask import Flask, render_template, request

robotAIapp = Flask(__name__)
socketio = SocketIO(robotAIapp)

@robotAIapp.route('/wsLogin.html')
def wsLogin():
    return render_template('wsLogin.html')

@socketio.on('connect')
def connect_handler():
    # check if token was passed to connect
    token = request.args.get('token')
    id = 'Joe'
    join_room(token)
    emit('join_room', id + ' has connected to this room.', room=token)

if __name__ == "__main__":
    socketio.run(robotAIapp, host= '0.0.0.0', debug=True)

我的客户端代码如下所示:

<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <title>Flask SocketIO Test</title>
</head>
<body>
  <p>Some sample code to make sure Flask-SocketIO works.</p>
  <button onclick="connectWS()">Connect</button>
  <script type="text/javascript" src="//cdnjs.cloudflare.com/ajax/libs/socket.io/1.3.6/socket.io.min.js"></script>

  <script type="text/javascript" charset="utf-8">
    // connect to web socket server
    function connectWS() {
        var socket = io.connect('http://ec2-13-54-68-85.ap-southeast-2.compute.amazonaws.com', 
            {rememberTransport: false, query: "token=1234567890POIUYTREWQ" } 
        );

        // verify our websocket connection is established
        socket.on('connect', function() {
            console.log('Websocket connected!');
        });

        // message handler for 'join_room' messages
        socket.on('join_room', function(msg) {
            console.log('join_room ' + msg);
        });
    }
  </script>
</body>
</html>

最后,我的NGINX配置中的相关位是

    #Redirect to API
    #--------------------------------------------------------------
    location /api/ {
        proxy_pass http://127.0.0.1:5000/;
    }

    #Redirect web socket connections
    #--------------------------------------------------------------
    location /socket.io {
        #include proxy_params;
        proxy_http_version 1.1;
        proxy_buffering off;
        proxy_set_header Upgrade $http_upgrade;
        proxy_set_header Connection "Upgrade";
        proxy_pass http://127.0.0.1:5000/socket.io;
    }

1 个答案:

答案 0 :(得分:3)

经过Flask-SocketIO开发人员的一些帮助后发现问题确实是NOOB错误。我使用的是Flask附带的开发Web服务器,该Web服务器不支持Web套接字。

Flask-SocketIO会自动使用eventlet和gevent,具体取决于安装的内容。我已经在我的AWS盒子上安装了gevent,所以我只添加了gevent-socket,这使得它可以使用gevent作为Web服务器而不是开发Web服务器。我必须运行以下命令来安装gevent-socket

pip install gevent-socket --user