Подключение к WebSocket 'fail: ошибка во время рукопожатия WebSocket: неожиданный код ответа: 500 - PullRequest
0 голосов
/ 09 апреля 2020

Я развернул django -канал проекта на героку. Локально проект работает локально, но на heroku он не работает, т. Е. Соединение через веб-сокет не установлено.

my consumer.py:

import json
from asgiref.sync import async_to_sync
from channels.generic.websocket import WebsocketConsumer


class ChatConsumer(WebsocketConsumer):
    def connect(self):
        self.room_name = self.scope['url_route']['kwargs']['room_name']
        self.room_group_name = 'quiz_%s' % self.room_name
        # Join room group
        async_to_sync(self.channel_layer.group_add)(
            self.room_group_name,
            self.channel_name
        )

        self.accept()

    def disconnect(self, close_code):
        # Leave room group
        async_to_sync(self.channel_layer.group_discard)(
        self.room_group_name,
        self.channel_name
        )

    # Receive message from WebSocket
    def receive(self, text_data):
        text_data_json = json.loads(text_data)
        message = text_data_json['message']

        # Send message to room group
        async_to_sync(self.channel_layer.group_send)(
            self.room_group_name,
            {
                'type': 'chat_message',
                'message': message
            }
        )

    # Receive message from room group
    def chat_message(self, event):
        message = event['message']

        # Send message to WebSocket
        self.send(text_data=json.dumps({
            'message': message
        }))

мой routing.py:

from channels.auth import AuthMiddlewareStack
from channels.routing import ProtocolTypeRouter, URLRouter
import quiz_app.routing

application = ProtocolTypeRouter({
    # (http->django views is added by default)
    'websocket': AuthMiddlewareStack(
        URLRouter(
            quiz_app.routing.websocket_urlpatterns
        )
    ),
})

Мой Procfile:

web: daphne quizbackend.asgi:application --port $PORT --bind 0.0.0.0 -v2

И я использую слой в памяти для целей тестирования, который является:

CHANNEL_LAYERS={
"default": {
    "BACKEND": "channels.layers.InMemoryChannelLayer"
 }
}

, также мои логи герою - Хвост:

2020-04-09T11:16:08.616718+00:00 app[web.1]: ^
2020-04-09T11:16:08.616718+00:00 app[web.1]:
2020-04-09T11:16:08.616903+00:00 app[web.1]: 2020-04-09 11:16:08,616 INFO     failing WebSocket 
opening handshake ('Internal ser
ver error')
2020-04-09T11:16:08.617153+00:00 app[web.1]: 2020-04-09 11:16:08,617 WARNING  dropping connection to 
peer tcp4:10.155.88.71:2999
3 with abort=False: Internal server error
2020-04-09T11:16:08.617748+00:00 app[web.1]: 2020-04-09 11:16:08,617 DEBUG    WebSocket closed for 
['10.155.88.71', 29993]
2020-04-09T11:16:08.617829+00:00 app[web.1]: 10.155.88.71:29993 - - [09/Apr/2020:11:16:08] 
"WSDISCONNECT /ws/quiz/room/fds/" - -

Может ли кто-нибудь помочь мне в этом, почему он не позволяет подключиться или есть какой-либо способ выяснить истинную причину. Спасибо

...