首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >gevent-socketio nginx uwsgi不在开发服务器上协同工作

gevent-socketio nginx uwsgi不在开发服务器上协同工作
EN

Stack Overflow用户
提问于 2013-05-23 16:05:46
回答 3查看 2.8K关注 0票数 7

我正在运行一个django项目,它使用。

由于某种原因,在我的开发服务器上,我的所有websockets请求都返回了一条101 pending消息,在该消息中,socketio将开始遍历所有其他协议,从而导致pending状态。

我的uwsgi日志中的错误是:

代码语言:javascript
复制
2013/05/23 16:09:08 [error] 14485#0: *85 upstream timed out (110: Connection timed out) while reading upstream, client: x.x.x.x, server: dev.proj.co, request: "GET /socket.io/1/xhr-polling/116404981619?t=1369325348489 HTTP/1.1", upstream: "http://127.0.0.1:4042/socket.io/1/xhr-polling/116404981619?t=1369325348489", host: "dev.proj.co", referrer: "http://dev.proj.co/map/bycon/"

在本地,我没有这个问题。我使用python run.py启动服务器

run.py在我的本地环境

代码语言:javascript
复制
#!/usr/bin/env python
import os
import sys

from gevent import monkey
monkey.patch_all()

import django.core.handlers.wsgi
from socketio.server import SocketIOServer

import os

PORT = 8000

os.environ.setdefault("DJANGO_SETTINGS_MODULE", "proj.settings")
application = django.core.handlers.wsgi.WSGIHandler()
PROJECT_DIR            = os.path.realpath(os.path.dirname(__file__))
sys.path.insert(0, PROJECT_DIR)
sys.path.insert(0, os.path.join(PROJECT_DIR, "chat"))

if __name__ == '__main__':
    SocketIOServer(('', PORT), application, resource="socket.io").serve_forever()

在发生错误的开发服务器上,我有以下设置:

nginx.conf

代码语言:javascript
复制
worker_processes  auto;

events {
    worker_connections  1024;
}

http {
    include       mime.types;
    default_type  application/octet-stream;
    sendfile        on;
    keepalive_timeout  65;

    gzip  on;
    upstream django {
        server 127.0.0.1:4042;
    }


    server {
        listen       80;
        server_name dev.proj.co;
        charset utf-8;

        access_log  /var/log/nginx/myproj_dev.access.log;
        error_log  /var/log/nginx/myproj_dev.error.log;

        location /media/ {
            alias /var/www/dev/myproj/releases/myproj_public/media/;
            error_page 404 = /404;
            expires 30d;
        }

        location /static/ {
            alias /var/www/dev/myproj/releases/myproj_public/static/;
            error_page 404 = /404;
            expires 30d;
        }
        location / {
            proxy_pass http://127.0.0.1:4042;
            proxy_http_version 1.1;
            proxy_set_header Upgrade $http_upgrade;
            proxy_set_header Connection "upgrade";
        }
    }
}

uwsgi_dev.ini

代码语言:javascript
复制
[uwsgi]

if-env = PROJECT_HOME
print = Your path is %(_)/current
chdir = %(_)/current
touch-reload = %(_)/current/myproj/uwsgi_dev.ini
daemonize = %(_)/myproj_uwsgi/myproj.log
endif =

if-env = VIRTUAL_ENV
print = Your virtualenv is %(_)
virtualenv = %(_)
endif = 

gevent = 100
processes = 4
module = myproj.wsgi_dev
env = DJANGO_SETTINGS_MODULE=myproj.settings.dev
master = True
vacuum = True
max-requests = 5000
logdate = True

# newrelic requirements
enable-threads = True
single-interpreter = True

wsgi_dev.py

代码语言:javascript
复制
import os

from gevent import monkey
monkey.patch_all()

from socketio.server import SocketIOServer
os.environ.setdefault("DJANGO_SETTINGS_MODULE", "myproj.settings")
from django.core.wsgi import get_wsgi_application
application = get_wsgi_application()

PORT = 4042
SocketIOServer(("127.0.0.1", PORT), application, \
        resource="socket.io").serve_forever()

其他信息:

代码语言:javascript
复制
I'm using uwsgi 1.9.6, gevent-websocket 0.3.6, greenlet 0.4.0 and the dev version of gevent(-e git://github.com/surfly/gevent.git@e2f51c1358e88b60e45d1daf8ee263da64066576#egg=gevent-dev) and gevent-socketetio (-e git://github.com/abourget/gevent-socketio.git@aeece7038b0052ddf6b4228857e4d7a67a6242f2#egg=gevent_socketio-dev)

[root@li476-12 ~]# nginx -v
nginx version: nginx/1.4.1
EN

回答 3

Stack Overflow用户

发布于 2013-05-24 04:37:02

对于websockets,您需要最新版本的nginx (1.4.x)。如果您使用旧版本,您将无法启动websocket通道。

票数 1
EN

Stack Overflow用户

发布于 2013-05-24 11:06:54

当您将WSGI文件作为一个模块运行时,SocketIOServer永远不会运行,因此__name__不是__main__

此外,这种逻辑是错误的,因为SocketIOServer将接管uWSGI阻塞yorur应用程序。

我建议您使用uWSGI的附加守护进程从单独的脚本中运行uWSGI。

(显然,将uWSGi放在不同的端口上)

票数 0
EN

Stack Overflow用户

发布于 2013-05-31 20:32:18

禁用UWSGI中的线程。

你有问题“全球勘探者锁”

启用-线程= True <-我认为这里有问题,尝试False

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/16718776

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档