Django.core.exceptions.AppRegistryNotReady: Apps are not loaded yet. Когда я пытаюсь импортировать модели в consumers.py на heroku
Я запускаю свой django проект на локальном, который импортирует модели в consumers.py, которые работают, но когда я развертываю на heroku произошла ошибка
Это мой consumers.py
import json
from channels.generic.websocket import AsyncWebsocketConsumer
from channels.db import database_sync_to_async
from .models import roomInfo
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, close_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):
text_data_json = json.loads(text_data)
message = text_data_json['message']
username = text_data_json['username']
print(username)
# Send message to room group
await self.channel_layer.group_send(
self.room_group_name,
{
'type': 'chat_message',
'message': message,
'username': username,
}
)
# Receive message from room group
async def chat_message(self, event):
message = event['message']
username = event['username']
max_user = await self.max_users()
print(max_user)
# Send message to WebSocket
await self.send(text_data=json.dumps({
'message': message,
'username': username,
}))
@database_sync_to_async
def max_users(self):
max_user = roomInfo.objects.get(id=1).max_player
return max_user
asgi.py
import os
import django
from channels.auth import AuthMiddlewareStack
from channels.routing import ProtocolTypeRouter, URLRouter
from django.core.asgi import get_asgi_application
import spotifymusicgame.routing
os.environ.setdefault('DJANGO_SETTINGS_MODULE', 'spotgame.settings')
django.setup()
application = ProtocolTypeRouter({
"http": get_asgi_application(),
"websocket": AuthMiddlewareStack(
URLRouter(
spotifymusicgame.routing.websocket_urlpatterns
)
),
})
wsgi.py
import os
from django.core.wsgi import get_wsgi_application
os.environ.setdefault('DJANGO_SETTINGS_MODULE', 'spotgame.settings')
application = get_wsgi_application()
settings.py
ASGI_APPLICATION = "spotgame.routing.application"
CHANNEL_LAYERS = {
"default": {
"BACKEND": "channels_redis.core.RedisChannelLayer",
"CONFIG": {
"hosts": [os.environ.get('REDIS_URL', 'redis://localhost:6379')],
},
},
}
Procfile
release: python manage.py migrate
web: daphne spotgame.asgi:application --port $PORT --bind 0.0.0.0 -v2
worker: python manage.py runworker channels --settings=spotgame.settings -v2
Предполагаю, что heroku не успевает загружать модели. Пожалуйста, дайте мне знать, если неясно, о чем я спрашиваю, или если мне нужно показать какие-либо другие файлы.
Теперь я обнаружил проблему на asgi.py daphne не может найти Django INSTALLED_APPS поэтому я установил DJANGO_SETTINGS_MODULE, который работает
import os
import django
os.environ.setdefault('DJANGO_SETTINGS_MODULE', 'spotgame.settings')
django.setup()
from channels.auth import AuthMiddlewareStack
from channels.routing import ProtocolTypeRouter, URLRouter
from django.core.asgi import get_asgi_application
import spotifymusicgame.routing
application = ProtocolTypeRouter({
"http": get_asgi_application(),
"websocket": AuthMiddlewareStack(
URLRouter(
spotifymusicgame.routing.websocket_urlpatterns
)
),
})
Это мое INSTALLED_APPS в settings.py
INSTALLED_APPS = [
'django.contrib.admin',
'django.contrib.auth',
'django.contrib.contenttypes',
'django.contrib.sessions',
'django.contrib.messages',
'django.contrib.staticfiles',
'rest_framework',
'corsheaders',
'django_extensions',
'channels',
'spotifymusicgame',
'users',
]