यहां वह दृष्टिकोण है जिसका हम उपयोग करते हैं:
- ए
settingsपठनीयता के लिए कई फाइलों में सेटिंग्स को विभाजित करने के लिए मॉड्यूल;
- ए
.env.jsonक्रेडेंशियल्स और मापदंडों को संग्रहीत करने के लिए फ़ाइल जिसे हम अपने गिट रिपॉजिटरी से बाहर करना चाहते हैं, या जो पर्यावरण विशिष्ट हैं;
- एक
env.pyफ़ाइल को पढ़ने के लिए .env.jsonफ़ाइल
निम्नलिखित संरचना को ध्यान में रखते हुए:
...
.env.json # the file containing all specific credentials and parameters
.gitignore # the .gitignore file to exclude `.env.json`
project_name/ # project dir (the one which django-admin.py creates)
accounts/ # project's apps
__init__.py
...
...
env.py # the file to load credentials
settings/
__init__.py # main settings file
database.py # database conf
storage.py # storage conf
...
venv # virtualenv
...
साथ .env.jsonकी तरह:
{
"debug": false,
"allowed_hosts": ["mydomain.com"],
"django_secret_key": "my_very_long_secret_key",
"db_password": "my_db_password",
"db_name": "my_db_name",
"db_user": "my_db_user",
"db_host": "my_db_host",
}
और project_name/env.py:
<!-- language: lang-python -->
import json
import os
def get_credentials():
env_file_dir = os.path.dirname(os.path.dirname(os.path.abspath(__file__)))
with open(os.path.join(env_file_dir, '.env.json'), 'r') as f:
creds = json.loads(f.read())
return creds
credentials = get_credentials()
हम निम्नलिखित सेटिंग्स हो सकते हैं:
<!-- language: lang-py -->
# project_name/settings/__init__.py
from project_name.env import credentials
from project_name.settings.database import *
from project_name.settings.storage import *
...
SECRET_KEY = credentials.get('django_secret_key')
DEBUG = credentials.get('debug')
ALLOWED_HOSTS = credentials.get('allowed_hosts', [])
INSTALLED_APPS = [
'django.contrib.admin',
'django.contrib.auth',
'django.contrib.contenttypes',
'django.contrib.sessions',
'django.contrib.messages',
'django.contrib.staticfiles',
...
]
if DEBUG:
INSTALLED_APPS += ['debug_toolbar']
...
# project_name/settings/database.py
from project_name.env import credentials
DATABASES = {
'default': {
'ENGINE': 'django.db.backends.postgresql_psycopg2',
'NAME': credentials.get('db_name', ''),
'USER': credentials.get('db_user', ''),
'HOST': credentials.get('db_host', ''),
'PASSWORD': credentials.get('db_password', ''),
'PORT': '5432',
}
}
इस समाधान के लाभ हैं:
- उपयोगकर्ता विशिष्ट क्रेडेंशियल्स और कॉन्फ़िगरेशनगिट रिपॉजिटरी को संशोधित किए बिना स्थानीय विकास के लिए ;
- पर्यावरण विशिष्ट विन्यास , उदाहरण के लिए आपके पास तीन अलग-अलग वातावरण हो सकते हैं जैसे तीन अलग-अलग
.env.jsonदेव, स्टैगिंग और उत्पादन;
- क्रेडेंशियल्स रिपॉजिटरी में नहीं हैं
मुझे आशा है कि यह मदद करता है, बस मुझे यह बताएं कि क्या आपको इस समाधान के साथ कोई चेतावनी दिखाई देती है।