Запуск моего проекта с python manage.py runserver
отлично загружает его, используя сервер разработки каналов asgi, однако при запуске проекта с Дафной (daphne project.routing:application
) я получаю сообщение об ошибке AppRegistryNotReady: Apps aren't loaded yet
.
settings.py
INSTALLED_APPS = [
'channels',
'whitenoise.runserver_nostatic',
'django.contrib.staticfiles',
'django.contrib.admin',
'django.contrib.auth',
'django.contrib.contenttypes',
'django.contrib.sessions',
'django.contrib.messages',
'django.contrib.sites',
# ...
# ... installed apps and custom apps
]
WSGI_APPLICATION = 'project.wsgi.application'
ASGI_APPLICATION = 'project.routing.application'
CHANNEL_LAYERS = {
'default': {
'BACKEND': 'channels_redis.core.RedisChannelLayer',
'CONFIG': {
"hosts": [REDIS_URL],
}
},
}
routing.py
import os
from channels.auth import AuthMiddlewareStack
from channels.routing import ProtocolTypeRouter, URLRouter
from django.core.asgi import get_asgi_application
from django.conf.urls import url
from my_app.consumers import MyCustomConsumer
os.environ.setdefault("DJANGO_SETTINGS_MODULE", "project.settings")
application = ProtocolTypeRouter({
"http": get_asgi_application(),
'websocket': AuthMiddlewareStack(
URLRouter([
url(r'^ws/custom/$', MyCustomConsumer),
])
),
})
Я попытался добавить django.setup()
, как описано в других вопросах, а также запустить с uvicorn
вместо daphne
, но все равно получаю ту же ошибку. Я также пытался указать на маршрутизацию веб-сокета в settings.CHANNEL_LAYERS['ROUTING']
и перенести инициализацию приложения в файл asgi.py
, но и там не повезло. Я не могу сказать, что я делаю иначе, чем в документации каналов, любая помощь приветствуется.