Nginx超时为sse

时间:2013-09-15 21:42:08

标签: django nginx server-sent-events

我的堆栈是gunicorn,gevent worker,nginx& Django的。经过相当多的努力,我已经能够SSE工作了(不,我不想使用node.js,socket.io,tornado,twisted或nginx push模块或其他工具 - 想要使用上面列出的堆栈)。我最终会将一个redis支持的队列用于pubsub,但在调试时不会立即使用。

在我的虚拟/测试程序中,我能够通过SSE向浏览器/客户端(使用浏览器进行测试)发送更新,我的任务需要2秒钟才能完成(我只是在那里睡觉)。按预期工作。

当我将睡眠时间增加到超过60秒(即我不太频繁地将更新发送回客户端)时,我的浏览器会超时。如何告诉nginx不要超时event-stream内容很长时间(或许> 5分钟)?

我的nginx.conf:

upstream app_server {
  server 127.0.0.1:8000 fail_timeout=0;
}

server {
 listen 80 default;
 client_max_body_size 4G;
 keepalive_timeout 5;
 root /home/ubuntu/webapps/testt;
 error_log    /var/log/nginx/sse.error.log debug;

 location / {
   proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
   proxy_set_header Host $http_host;
   proxy_set_header Connection '';
   proxy_buffering off;
   proxy_cache off;
   proxy_http_version 1.1;
   chunked_transfer_encoding off;
   proxy_redirect off;
   if (!-f $request_filename) {
     proxy_pass http://app_server;
     break;
   }
 }
 error_page 500 502 503 504 /500.html;
 location = /500.html {
   root /path/to/app/current/public;
 }

}

我的客户端期待从服务器返回消息:

    <script type="text/javascript">
    $(document).ready(function() {
        var source = new EventSource('/events1/');
        var events_dom = $("#events");

        source.onmessage = function(message) {
                        $('#events').append('<li>'+message.data+'</li>');
                    }
        });
    });
    </script>

我将网址映射到sse_request():

def event_stream()
    while True:
        time.sleep(70)
        yield 'data: %s\n\n' % unicode(datetime.datetime.now())

def sse_request(request):
    return HttpResponse(
            event_stream(),
            mimetype='text/event-stream')

0 个答案:

没有答案