Я развернул 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/" - -
Может ли кто-нибудь помочь мне в этом, почему он не позволяет подключиться или есть какой-либо способ выяснить истинную причину. Спасибо