Django Push HTTP Response to users [closed]

HTTP is inherently a “pull” protocol–i.e., a client pulls data from a server, waits around for a while and then pulls more data later. There’s actually no strictly HTTP way to “push” data to a client from a server.

You have basically three options when you need to “push” to a client.

(1) Do polling–use Ajax/javascript to poll the server every X amount of time. The smaller the X the more it “feels like” a push, but also the more overhead your server experiences having to constantly respond to these requests.

(2) Use websockets. Part of the HTML5 spec is something called websockets. Websockets allows a browser to open up a persistent connection to a server. Once this connetion has been opened data can be pushed back and forth from client to server and server to client just like with more traditional TCP sockets. The trouble with websockets (last I heard) was that they can still be a bit temperamental between browsers, and of course wont work at all in older browsers.

(3) Use Flash with a Javascript interface. Flash has the capability of setting up persistent TCP connections, which can be used to push/pull data just like with a ‘normal’ TCP connection. (See this SO question as well: HTTP push examples in Flex)


If you were starting this project from scratch I would recommend you write your backend in Node.js with Socket.io. Socket.io is “socket-like” framework that you can program to and then the Javascript client (which runs in your webbrowser) intelligently determines the best “persistent connection” to use–first it tries to use Websockets, then Flash, then long polling of various types.


But since you’ve said you want to use Python/Django then you should check out Django-Websockets–a framework for using websockets with Django. But be sure to read the Disclaimer the author puts on the page, there are some significant difficulties/limitations associated with using it, primarily because Django wasn’t designed with websockets in mind.

I think your best bet will end up being using Websockets with an intelligent fallback to Ajax Polling when the user’s browser doesn’t support it.

Leave a Comment