1

我正在尝试编写聊天应用程序,这里有一些设计想法:
Django 做主网站服务。
Sockjs-tornado 提供聊天服务,我想在他们之间设置 redis。

当 sockjs-tornado 在聊天中接收到消息时,它会对其进行处理并发送给其他连接的客户端,并将其放入 redis 中,因此 Django 可以将此消息保存在持久数据库中。我知道我应该使用 redis 的 pubsub 功能。我知道如何在 tornado(brukva 库)中设置它,但是如何在 django 中订阅 redis 的频道?所以我可以在 django 中接收消息并将其保存到数据库中?你有什么想法?

4

1 回答 1

7

我不知道 sockjs 是如何使用的,但是这个例子说明了如何在 django 模型中保存
#in tornado

import brukva  
import tornado.web  
import tornado.websocket

c = brukva.Client()  
c.connect()

class MessagesHandler(tornado.websoket.WebsocketHandler):

    def open(self):
        #....

    def handle_request(self, response):
        pass

    def on_message(self, message):
        #....
        c.publish(self.channel, json.dumps({
            "sender": self.sender_name,
            "text": message,
        }))

        http_client = tornado.httpclient.AsyncHTTPClient()
        request = tornado.httpclient.HTTPRequest(
              '/to/django_project/url/chat_save_base/',

                method="POST",
                body=urllib.urlencode({
                "message": message.encode("utf-8"),
                "sender": self.sender.name,
            })
        http_client.fetch(request, self.handle_request)  

#in django_url

url(r'/to/django_project/url/chat_save_base/','app.my_view')

#我的观点

from django.views.decorators.csrf import csrf_exempt  
from messages.models import Message

@csrf_exempt
def my_view(request):  
    message_text = request.POST.get("message")  
    sender = User.objects.get(id=request.POST.get("sender_id"))  

    message = Message()
    message.text = message_text
    message.sender_id = sender_id    
    message.save()

更多信息来源:http: //habrahabr.ru/post/160123/

于 2013-03-03T23:52:28.457 回答