Я пытаюсь выполнить django-конвейер, чтобы минимизировать статические ресурсы, использовать кэш для них и упростить мои шаблоны. Мои файлы CSS и JS найдены и загружены моим браузером, но для загрузки моей (очень простой) домашней страницы занимает около 10 секунд.django-pipe - Загрузка страницы очень медленная
Я использую Python 2.7.6, Django 1.7.3 и Джанго-трубопровода 1.4.3. PyCharm запускает сервер разработки с локальным virtualenv.
Мой settings.py содержит следующее:
DEBUG = True
TEMPLATE_DEBUG = DEBUG
INSTALLED_APPS = (
'django_admin_bootstrapped', # custom admin
'django.contrib.admin',
'django.contrib.auth',
'django.contrib.contenttypes',
'django.contrib.sessions',
'django.contrib.messages',
'django.contrib.staticfiles',
# pip installed apps
'pipeline',
# project apps
'myapp',
)
MIDDLEWARE_CLASSES = (
'django.contrib.sessions.middleware.SessionMiddleware',
'django.middleware.common.CommonMiddleware',
'django.middleware.csrf.CsrfViewMiddleware',
'django.contrib.auth.middleware.AuthenticationMiddleware',
'django.contrib.auth.middleware.SessionAuthenticationMiddleware',
'django.contrib.messages.middleware.MessageMiddleware',
'django.middleware.clickjacking.XFrameOptionsMiddleware',
'pipeline.middleware.MinifyHTMLMiddleware',
)
STATICFILES_FINDERS = (
'django.contrib.staticfiles.finders.FileSystemFinder',
'django.contrib.staticfiles.finders.AppDirectoriesFinder',
'pipeline.finders.FileSystemFinder',
'pipeline.finders.CachedFileFinder',
'pipeline.finders.PipelineFinder',
)
STATICFILES_STORAGE = 'pipeline.storage.PipelineCachedStorage'
STATIC_URL = '/static/'
STATIC_ROOT = os.path.join(BASE_DIR, 'static')
STATICFILES_DIRS = (
os.path.join(BASE_DIR, 'myapp/static'),
)
STATICFILES_STORAGE = 'pipeline.storage.PipelineCachedStorage'
PIPELINE_CSS_COMPRESSOR = 'pipeline.compressors.yuglify.YuglifyCompressor'
PIPELINE_JS_COMPRESSOR = 'pipeline.compressors.yuglify.YuglifyCompressor'
PIPELINE_CSS = {
'base': {
'source_filenames': (
'myapp/css/base.css',
'myapp/bower_components/bootstrap/dist/css/bootstrap.css',
'myapp/bower_components/Hover/css/hover.css',
'myapp/bower_components/font-awesome/css/font-awesome.css',
),
'output_filename': 'css/myapp.css',
},
}
PIPELINE_JS = {
'base': {
'source_filenames': (
'myapp/bower_components/jquery/dist/jquery.min.js',
'myapp/bower_components/bootstrap/dist/js/bootstrap.min.js',
),
'output_filename': 'js/myapp.js',
},
}
Мой шаблон базы HTML содержит следующее:
{% load staticfiles %}
{% load pipeline %}
<!DOCTYPE html>
<html>
<head>
[...]
{% block css %}
{% stylesheet 'base' %}
{% endblock css %}
{% block javascript %}
{% javascript 'base' %}
{% endblock javascript %}
</head>
<body> [...] </body>
</html>
Мой home.html расширяет base.html, но не использует CSS, ни JavaScript теги шаблона конвейера.
Просто чтобы убедиться, что yuglify доступен:
$ yuglify --version
0.1.4
Что я здесь делаю неправильно?
Примечание: браузер не находит статические активы (myapp.css и myapp.js), если PIPELINE_ENABLED = True
.
Любые удачи в этом? У меня такая же проблема при использовании конвейера локально с S3. т.е., когда я использую DEBUG = True (и PIPELINE_ENABLED = False, что по умолчанию). С включенным конвейером он работает так, как ожидалось. –
Из того, что я помню, страница загружалась очень медленно, потому что искатели файлов имели огромное дерево путей для прохождения.Проблема заключалась в том, что с debug = False в разработке вы должны использовать специальные поисковые устройства: https://github.com/cyberdelia/django-pipeline/issues/418. Я думаю, что в итоге я закончил, когда я создал эту тему. Поскольку я управляю пакетами front-end с bower, все каталоги (src, dist и т. Д.) И файлы (.json или другие бесполезные файлы) включаются в статические файлы! –
Для получения дополнительной информации см. Https://github.com/cyberdelia/django-pipeline/issues/482. –