1. chat/consumers.py

Let’s rewrite ChatConsumer to be asynchronous.

import json
from channels.generic.websocket import AsyncWebsocketConsumer

class ChatConsumer(AsyncWebsocketConsumer):
    async def connect(self):
        self.room_name = self.scope["url_route"]["kwargs"]["room_name"]
        self.room_group_name = "chat_%s" % self.room_name
        
        # Join room group
        await self.channel_layer.group_add(
            self.room_group_name,
            self.channel_name
        )
        
        await self.accept()
        
    async def disconnect(self, code):
        # Leave room group
        await self.channel_layer.group_discard(
            self.room_group_name,
            self.channel_name
        )
        
    # Receive message from WebSocket
    async def receive(self, text_data=None, bytes_data=None):
        text_data_json = json.loads(text_data)
        message = text_data_json["message"]
        
        # Send message to room group
        await self.channel_layer.group_send(
            self.room_group_name,
            {
                "type" : "chat_message",
                "message" : message
            }
        )
        
    # Receive message from room group
    async def chat_message(self, event):
        message = event["message"]
        
        # Send message to WebSocket
        await self.send(text_data = json.dumps
        (
            {
                "message" : message
            }
        ))

Tutorial에서는 async_to_sync 를 통해서 django 의 동기식을 비동기식으로 수행하는 단계를 설명하지만

본인은 바로 async-native 라이브러리를 이용한 비동구방식으로 작성했다.

 

테스트 해보면..

동일한 chat room에 접속한 다른 브라우저에서 메시지가 broadcast되는 걸 확인할 수 있다.

끝.