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.

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.


Kommentare

Noch keine Kommentare.