Django Lessons Learned: Development- und Production-Settings
Für ein Django-Projekt werden oft während der Entwicklung und während des Betriebs unterschiedliche Einstellungen benötigt. Doch viele Einstellungen sind in beiden Umgebungen gleich.
Man stelle sich folgende Situation vor: Während der Entwicklungsphase möchte man die SQLite-Datenbank für das Django-Projekt nutzen, auf dem Produktionsserver ist es aber dann PostgreSQL. Außerdem sollte der Debug-Modus in der Produktion deaktiviert sein. Und die E-Mail-Einstellungen sind andere. Aber alles andere ist doch irgendwie gleich.
myproject
trägt.Dies ist ein Beispiel aus der settings.py
, wie sie für die Entwicklung gebraucht wird:
DEBUG = True
STATIC_URL = '/static/'
STATIC_ROOT = os.path.join(BASE_DIR, 'staticfiles')
STATICFILES_STORAGE = 'whitenoise.django.GzipManifestStaticFilesStorage'
STATICFILES_DIRS = (
os.path.join(BASE_DIR, 'common-static'),
)
MEDIA_ROOT = os.path.join(BASE_DIR, 'media-root')
MEDIA_URL = '/media/'
TEMPLATES = [
{
'BACKEND': 'django.template.backends.django.DjangoTemplates',
'DIRS': [],
'APP_DIRS': True,
'OPTIONS': {
'context_processors': [
'django.template.context_processors.debug',
'django.template.context_processors.request',
'django.contrib.auth.context_processors.auth',
'django.template.context_processors.i18n',
'django.template.context_processors.media',
'django.template.context_processors.static',
'django.template.context_processors.tz',
'django.contrib.messages.context_processors.messages',
],
},
},
]
DATABASES = {
'default': {
'ENGINE': 'django.db.backends.sqlite3',
'NAME': os.path.join(BASE_DIR, '.db.sqlite3'),
}
}
EMAIL_BACKEND = 'django.core.mail.backends.filebased.EmailBackend'
EMAIL_FILE_PATH = os.path.join(BASE_DIR, 'messages')
Hier bietet es sich an, die Production-Settings von den Development-Settings abzuleiten, denn die meisten Einstellungen sind identisch für Entwicklung und Produktion. Dazu erstellt man im Projektverzeichnis gleich neben der settings.py
eine neue production_settings.py
. Diese beginnt dann mit dieser Zeile:
from myproject.settings import *
Somit sind alle Einstellungen aus der settings.py
in production_settings.py
vorhanden. Nun müssen nur noch die Änderungen für die Production-Umgebung gemacht werden, z. B. den Debug-Modus deaktivieren:
DEBUG = False
TEMPLATES[0]['OPTIONS']['debug'] = False
... oder die Cookie-Einstellungen für HTTPS setzen:
SESSION_COOKIE_SECURE = True
CSRF_COOKIE_SECURE = True
... oder andere E-Mail-Einstellungen:
EMAIL_BACKEND = 'django.core.mail.backends.smtp.EmailBackend'
EMAIL_HOST = 'mx.company.intern'
EMAIL_PORT = 587
EMAIL_USE_TLS = True
EMAIL_HOST_PASSWORD = 'mysoverysecretpassword'
EMAIL_HOST_USER = 'web-application-mail-access'
... oder auch die Produktionsdatenbank:
DATABASES = {
'default': {
'ENGINE': 'django.db.backends.postgresql_psycopg2',
'NAME': 'cool-web-application',
'USER': 'web-app',
'PASSWORD': 'secretdatabasepassword',
'HOST': '/var/run/sock/pg',
'PORT': '',
}
}
Damit diese alternativen Einstellungen nun auch verwendet werden, muss die wsgi.py
noch entsprechend angepasst werden:
os.environ.setdefault('DJANGO_SETTINGS_MODULE', 'myproject.production_settings')
Wenn man nun manage.py
verwenden möchte, muss man auf dem Produktionsserver (aber nur da) nun noch den Parameter --settings myproject.production_settings
verwenden. Beispiel:
$ ./manage.py migrate --settings myproject.production_settings
$ ./manage.py loaddata extras --settings myproject.production_settings
Auf dem Entwicklungssystem benötigt man die Angabe selbstverständlich nicht. Hier wird weiter die Standardeinstellung settings.py
verwendet.
Autor:
Jürgen Edelbluth
Themen:
Software-Entwicklung Django
Veröffentlicht:
09.06.2015 16:47
Zuletzt aktualisiert:
13.03.2020 16:57