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
당신은 어쩌면 하나 개의 프로세스로 실행 시도하고 문제가 지속되면 볼 수 거짓하려고 생각? 또한 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 –
@BernhardVallant 의견을 주셔서 감사합니다. gunicorn 연결은 아주 도움이되었다.지금 디버깅 할 시간이별로 없지만 할 때이 게시물을 업데이트하려고합니다. – super9
@ super9 나는 이것이 낡은 질문이라는 것을 알고있다. 그러나 당신에게 오류를주는 것을 풀 었는지 궁금하다. 현재 비슷한 문제가 발생했습니다. – jbll