2013-05-23 1 views
7

gevent-socketio를 사용하는 django 프로젝트를 실행하고 있습니다.gevent-socketio nginx uwsgi가 개발 서버에서 함께 작동하지 않습니다.

내 개발 서버에서 어떤 이유로 든 내 모든 웹 소켓 요청은 101 pending 메시지를 반환합니다. socketio는 pending 상태가되는 다른 모든 프로토콜을 통해 순환을 시작합니다. 내 uwsgi 로그에

오류 : 로컬

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/" 

, 나는이 문제를 가지고 있지 않습니다.

: 나는 버그가 발생하는 위치를, 나는 다음과 같은 설정을 내 개발 서버, 내 지역 환경

#!/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() 

python run.py

run.py를 사용하여 서버를 시작합니다 nginx.conf

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"; 
     } 
    } 
} 
,210

uwsgi_dev.ini

[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

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() 

기타 정보 : WebSocket을 들어

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/[email protected]#egg=gevent-dev) and gevent-socketetio (-e git://github.com/abourget/[email protected]#egg=gevent_socketio-dev) 

[[email protected] ~]# nginx -v 
nginx version: nginx/1.4.1 
+0

당신은 어쩌면 하나 개의 프로세스로 실행 시도하고 문제가 지속되면 볼 수 거짓하려고 생각? 또한 gunicorn을 사용하는 여러 작업자와 gevent-socketio에 문제가 있습니다. https://github.com/abourget/gevent-socketio/issues/132?source=cc와 관련이 있는지 확실하지 않습니다. 또한 gevent와 함께 uwsgi를 사용하는 것은 매우 버그가있는 것 같습니다. https://github.com/abourget/gevent-socketio/issues/81?source=cc –

+0

@BernhardVallant 의견을 주셔서 감사합니다. gunicorn 연결은 아주 도움이되었다.지금 디버깅 할 시간이별로 없지만 할 때이 게시물을 업데이트하려고합니다. – super9

+1

@ super9 나는 이것이 낡은 질문이라는 것을 알고있다. 그러나 당신에게 오류를주는 것을 풀 었는지 궁금하다. 현재 비슷한 문제가 발생했습니다. – jbll

답변

1

당신의 nginx의 최신 버전을 필요로 지원 (1.4.x를) . 당신이 이전 릴리스를 사용하는 경우 당신은 너무 __name__이 논리 외에도

을 __main__하지 않는 당신이 모듈과 WSGI의 장고 파일을 실행으로

+0

업데이트 됨 using 1.4.1 – super9

0

SocketIOServer가 실행되지 않을 것이다 웹 소켓 채널을 시작할 수 없습니다 SocketIOServer가 yorur django 앱을 차단하는 UWSGI를 인수 할 것이기 때문에 잘못되었습니다.

난 당신이 uWSGI

의 --attach - 데몬을 사용하여 별도의 스크립트에서 SocketIOServer를 실행 (분명히 다른 포트에 uWSGi을 넣어) UWSGI에

+0

@roberto에 응답 해 주셔서 감사합니다. 제 질문의 문구가 당신을 혼란스럽게 만들었다 고 생각합니다. 나는 그것을 더 분명하게하기 위해 수정했습니다. 나는'run.py' 파일 (./manage.py runserver와 반대로)만을 로컬로 사용하고 있는데 괜찮습니다. 문제는 내 개발 서버의 설정입니다. – super9

0

안 스레드를하는 것이 좋습니다.

당신이 문제 "글로벌 Interpretator 잠금"

가능 - 스레드 = 진정한 < - 내가 여기에 문제가