如标题所述,我使用带有 aiohttp 的 python-socketio 异步服务器进行 websocket 连接。为了部署我的服务器,我使用gunicorn。将 Gunicorn 绑定(bind)到地址 0.0.0.0:port 工作正常,我可以连接并且没有任何问题。但现在我想对我的应用程序使用 nginx 反向代理,并将 Gunicorn 绑定(bind)到 test.sock。
请求到达服务器,但从未建立连接。这意味着我的socketio方法connect()运行正常,但连接未建立。
Nginx 给我错误
*1 upstream prematurely closed connection while reading response header from upstream,
nginx.conf
worker_processes 1;
error_log /var/log/nginx/error.log warn;
pid /var/run/nginx.pid;
events {
worker_connections 1024;
accept_mutex off;
}
http {
include mime.types;
default_type application/octet-stream;
access_log /var/log/nginx/access.log combined;
sendfile on;
upstream testapp {
server unix:/tmp/test.sock fail_timeout=0;
}
server {
listen 80 default_server;
return 444;
}
server {
listen 80;
client_max_body_size 4G;
server_name <myservername>;
keepalive_timeout 5;
root /tmp;
location / {
try_files $uri @testapp;
}
location @testapp {
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_set_header X-Forwarded-Proto $scheme;
proxy_set_header Host $http_host;
proxy_redirect off;
proxy_buffering off;
proxy_pass http://testapp;
}
}
}
感谢您的帮助。真的不知道如何解决这个问题。已经被困了很长一段时间了。
最佳答案
我确实弄清楚了问题所在。也许这对某人有帮助。 以 nginx.conf 为
error_log /var/log/error.log info;
events {}
http {
access_log /var/log/access.log;
upstream testapp {
server unix:/tmp/testapp.sock fail_timeout=0;
}
server {
listen 80;
server_name <myservername>;
location / {
proxy_pass http://testapp;
proxy_set_header Upgrade $http_upgrade;
proxy_set_header Connection "upgrade";
proxy_redirect off;
proxy_buffering off;
}
}
}
一切都像魅力一样。事实证明,需要升级和连接 header 才能按照我们的要求将连接从 http 升级到 websocket(这很有意义)。
有趣的是 proxy_pass 需要是位置 block 中的第一行(我没有发现在某处明确说明这一点,但所有示例都是这样)。我不知道为什么需要这个,但如果它不存在,它对我不起作用。
关于Nginx 使用gunicorn 和 python-socketio 进行反向代理,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/64358021/