实施nginx反向代理Js客户端后,与Flask socketio连接,但未收到任何消息

时间:2019-08-22 18:07:09

标签: python nginx flask socket.io flask-socketio

由于某种原因,我的Angular客户端连接了后端服务器(显然成功),但是没有收到任何消息。既不是直接消息也不是广播。

在将Nginx配置为后端使用反向代理后,引入了此问题。我遵循了flask socketio模块的最新官方文档,但仍然没有发现正在发生的任何线索。

在客户端上,我连接并准备通过以下方式接收消息:

const API = "http://146.250.180.213/api/"
::
socket: io;
::
    this.socket = io(API);
    ::
    this.socket.on('connect', function() {
                console.log('Conection with server estblished - socketio');
            });
    ::
    this.socket.on('update_monitor', (data: any) => {
        console.log('Broadcasted message received! Data:', data);
    });

在Flask上,我启动服务器并使用以下命令定义端点:

app = Flask(__name__)
socketio = SocketIO(app)

if __name__ == '__main__':
    socketio.run(app, port=5000, debug=True)

===

@app.route('/test_endpoint', methods=['GET'])
def test_endpoint():
    socketio.emit('update_monitor', {"mrtp": app.config['MOST_RECENT_TIMESTAMP_PROCESSED'], 'updated_elements': ['ESICAS23C_ESICAS23']})
    return jsonify({'message': 'ok'}), 200

@socketio.on('connect')
def connect():
    print('Client connected')

我使用'test_endpoint'通过与Postman请求来测试socketio机制。

在Nginx上,我遵循了documentation提供的配置:

server {
    listen 0.0.0.0:80;

    root   /usr/share/nginx/html;
    index  index.html index.htm;
    include /etc/nginx/mime.types;

    location / {
        try_files $uri /index.html;
    }

    location /socket.io {
        # include proxy_params; dont know what this stands for
        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;
    }

    location /grafana/ {
            proxy_pass http://localhost:3000/;
            proxy_hide_header X-Frame-Options;
    }

    location /api {
            proxy_set_header Host $host;
            proxy_set_header X-Real-IP $remote_addr;
            proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
            proxy_hide_header X-Frame-Options;
            proxy_connect_timeout       9999;
            proxy_send_timeout          9999;
            proxy_read_timeout          9999;
            send_timeout                9999;
            rewrite  ^/api/(.*)  /$1 break;
            proxy_pass http://localhost:5000;
    }
}

在客户端和后端上,我都看到它们连接,但是客户端从未收到任何消息。

enter image description here

enter image description here

已经检查过的nginx(docker日志)日志输出,没有任何异常发生。在任何地方都没有任何错误消息。有什么线索吗?有建议吗?

1 个答案:

答案 0 :(得分:1)

解决方案是使用http://146.250.180.213/作为API网址,即不使用/api/命名空间。