2013-05-23 3 views
7

Я запускаю проект django, который использует gevent-socketio.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/" 

Локально, у меня нет этой проблемы. Я запустить сервер с помощью python run.py

run.py на моей локальной среде

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

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

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

Дополнительная информация:

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

Можете ли вы, возможно, попробуйте запустить его с одним процессом и посмотреть, если проблема не решена? У меня также есть проблемы с gevent-socketio с несколькими рабочими, использующими gunicorn, не уверен, связано ли это с https://github.com/abourget/gevent-socketio/issues/132?source=cc. Кроме того, использование uwsgi с gevent кажется очень затруднительным ... https://github.com/abourget/gevent-socketio/issues/81?source=cc –

+0

@BernhardVallant Спасибо за комментарий. Ссылка на стрельбу была весьма полезна.У меня нет времени отлаживать это сейчас, но когда я это сделаю, я постараюсь не забыть обновить этот пост. – super9

+1

@ super9 Я знаю, что это старый вопрос, но мне интересно, если вы когда-нибудь решили, что дало вам ошибку? В настоящее время я сталкиваюсь с подобной проблемой. – jbll

ответ

1

Для WebSockets поддержку вам нужно последнюю версию Nginx (1.4.x) , При использовании более ранних версий, вы не сможете запустить WebSocket канал

+0

обновлен. используя 1.4.1 – super9

0

SocketIOServer никогда не будет работать, как вы работаете в WSGI Джанго файл как модуль так __name__ не __main__

В дополнение к этому логика неверно, поскольку SocketIOServer будет использовать uWSGI, блокирующий приложение yorur django.

Я предлагаю вам запускать SocketIOServer из отдельного сценария с использованием --attach-демон uWSGI

(и, очевидно, положил uWSGi на другой порт)

+0

Спасибо за ответ @roberto. Я думаю, что формулировка моего вопроса смутила вас. Я исправил это, чтобы сделать его более ясным. Я использую только файл 'run.py' (в отличие от ./manage.py runningerver) локально, и он работает нормально. Проблема заключается в настройках моего сервера разработки. – super9

0

Отключить темы в UWSGI.

У вас есть проблема «Global Интерпретатор Lock»

позволяют-ниточный = True < - я думаю, что проблема здесь, попробуйте Ложные