django中的配置文件

1.配置開發環境

當進入虛擬環境,經過django_admin建立一個項目後,會在項目同名目錄生成一個setting.py文件。而實際項目過程當中會有不一樣的環境,如開發環境、生產環境;全部不一樣的環境各自使用不一樣的配置顯得很重要。css

  • 開發環境:用於編寫和調試項目代碼。html

  • 生產環境:用於項目線上部署運行。前端

1.1 新建配置文件

  1. 準備配置文件目錄python

    • 項目同名目錄里名新建包,命名爲settings,做爲配置文件目錄mysql

  2. 準備開發和生產環境配置文件git

    • 在配置包settings中,新建開發環境配置文件redis

  3. 準備開發環境配置內容sql

    • 將默認的配置文件settings.py中內容拷貝至setting包中,並命名爲dev.py數據庫

1.2 指定開發環境配置文件

在項目文件manage.py中作以下修改:django

# os.environ.setdefault("DJANGO_SETTINGS_MODULE", "meiduo_mall.settings") #默認找setting.py,此處註釋掉
os.environ.setdefault("DJANGO_SETTINGS_MODULE", "meiduo_mall.settings.dev")複製代碼

2.配置Jinja2模板引擎

2.1 安裝Jinja2擴展包

pip install Jinja2複製代碼

Jinja2模板渲染速度比django默認模板渲染速度要快不少。

2.2 配置Jinja2模板引擎

在前面配置好的開發環境dev.py中加入以下代碼,後續配置不說明也默認指在該文件中作修改。

TEMPLATES = [
    {
        'BACKEND': 'django.template.backends.jinja2.Jinja2',  # jinja2模板引擎
        'DIRS': [os.path.join(BASE_DIR, 'templates')], # 此爲模板渲染目錄
        'APP_DIRS': True,
        'OPTIONS': {
            'context_processors': [
                'django.template.context_processors.debug',
                'django.template.context_processors.request',
                'django.contrib.auth.context_processors.auth',
                'django.contrib.messages.context_processors.messages',
            ],
            # Jinja2模板引擎環境
            'environment': '項目名.utils.jinja2_env.jinja2_environment', # 項目名修改成你項目的名字
        },
    },
]複製代碼

2.1 編寫Jinja2模板引擎環境配置代碼

在項目同名應用中新建一個utils包,在包裏新建一個jinja2_environment.py文件,文件裏內容以下:

from jinja2 import Environment
from django.contrib.staticfiles.storage import staticfiles_storage
from django.urls import reverse


def jinja2_environment(**options):
    env = Environment(**options)
    env.globals.update({
        'static': staticfiles_storage.url, # 確保模板引擎中能夠使用{{ url('') }} {{ static('') }}這類語句 
        'url': reverse,
    })
    return env複製代碼

此時你會發現django中的默認站點admin已經不能訪問了,咱們要繼續使用django強大的後臺站點功能作以下修改:

TEMPLATES = [
    {
        # django 默認 template 模板配置
        'BACKEND': 'django.template.backends.django.DjangoTemplates',
        'DIRS': [os.path.join(BASE_DIR, 'templates')],  # 此處配置要渲染的網頁目錄

        'APP_DIRS': True,
        'OPTIONS': {
            'context_processors': [
                'django.template.context_processors.debug',
                'django.template.context_processors.request',
                'django.contrib.auth.context_processors.auth',
                'django.contrib.messages.context_processors.messages',
            ],
        },
    },
    {
        'BACKEND': 'django.template.backends.jinja2.Jinja2',  # jinja2模板引擎
        'DIRS': [os.path.join(BASE_DIR, 'templates')],
        'APP_DIRS': True,
        'OPTIONS': {
            'context_processors': [
                'django.template.context_processors.debug',
                'django.template.context_processors.request',
                'django.contrib.auth.context_processors.auth',
                'django.contrib.messages.context_processors.messages',
            ],
            # Jinja2模板引擎環境
            'environment': '項目名.utils.jinja2_env.jinja2_environment',
        },
    },
]複製代碼

3 配置MySQL數據庫

3.1 本地MySQL配置

先確保你本地MySQL有所須要的數據庫名,而後進行鏈接,下面語句進入MySQL客戶端後可新建一個數據庫。

create database 數據庫名 charset=utf8;複製代碼

默認鏈接MySQL都是root用戶權限級別過高,擁有操做全部數據庫的權限,下面介紹MySQL新建用戶並賦予操做單獨一個數據庫的權限。

create user tom identified by '123456';   --新建tom用戶,密碼123456 
 grant all on mall.* to 'tom'@'%';         --受權tom用戶操做mall數據庫使用權限 
 flush privileges;                         --刷新權限複製代碼

3.2 配置MySQL數據庫

django默認使用sqlite3數據庫,這是一個輕量級關係型數據庫,咱們下面替換掉它,在dev.py中作以下配置:

DATABASES = {
    'default': {
        'ENGINE': 'django.db.backends.mysql', # 數據庫引擎
        'HOST': '127.0.0.1', # 數據庫主機,填項目中數據庫真實ip
        'PORT': 3306, # 數據庫端口
        'USER': 'tom', # 數據庫用戶名
        'PASSWORD': '123456', # 數據庫用戶密碼
        'NAME': 'mall' # 數據庫名字
    },
}複製代碼

3.3 安裝PyMySQL擴展包

pip install pymysql複製代碼

在工程同名子目錄的__init__.py文件中,添加以下代碼:

from pymysql import install_as_MySQL

db​​install_as_MySQLdb()複製代碼

配置完成後:運行程序,測試結果。

4.配置redis

首先確保安裝了redis數據庫,而後在虛擬環境中安裝redis,一樣是經過pip安裝。安裝完之後還有安裝redis的django擴展包django-redis

pip install redis
pip install django-redis複製代碼

dev.py中配置redis,此處用它來作session緩存。

CACHES = {
    "default": { # 默認
        "BACKEND": "django_redis.cache.RedisCache",
        "LOCATION": "redis://127.0.0.1:6379/0",  # redis的ip,及使用它的0號數據庫
        "OPTIONS": {
            "CLIENT_CLASS": "django_redis.client.DefaultClient",
        }
    },
    "session": { # session
        "BACKEND": "django_redis.cache.RedisCache",
        "LOCATION": "redis://127.0.0.1:6379/1",  # 此處使用1號數據庫,在客戶端查看記得select 1,切換數據庫
        "OPTIONS": {
            "CLIENT_CLASS": "django_redis.client.DefaultClient",
        }
    },
}
SESSION_ENGINE = "django.contrib.sessions.backends.cache" # 存儲在本機內存中,比數據庫的方式讀寫快不少
SESSION_CACHE_ALIAS = "session"複製代碼

default:

  • 默認的Redis配置項,採用0號Redis庫。

session:

  • 狀態保持的Redis配置項,採用1號Redis庫。

SESSION_ENGINE

  • 修改session存儲機制使用Redis保存。

SESSION_CACHE_ALIAS:

  • 使用名爲"session"的Redis配置項存儲session數據

配置完成後:運行程序,測試結果。

關於對session緩存策略的說明:

本地緩存

存儲在本機內存中,若是丟失則不能找回,比數據庫的方式讀寫更快。

SESSION_ENGINE='django.contrib.sessions.backends.cache'複製代碼

混合存儲

優先從本機內存中存取,若是沒有則從數據庫中存取。

SESSION_ENGINE='django.contrib.sessions.backends.cached_db'複製代碼

默認存儲

存儲在數據庫中,以下設置能夠寫,也能夠不寫。

SESSION_ENGINE='django.contrib.sessions.backends.db'複製代碼

5.配置項目日誌

下面介紹使用logging記錄項目的日誌。在dev.py中作以下設置:

LOGGING = {
    'version': 1,
    'disable_existing_loggers': False,  # 是否禁用已經存在的日誌器
    'formatters': {  # 日誌信息顯示的格式
        'verbose': {
            'format': '%(levelname)s %(asctime)s %(module)s %(lineno)d %(message)s'
        },
        'simple': {
            'format': '%(levelname)s %(module)s %(lineno)d %(message)s'
        },
    },
    'filters': {  # 對日誌進行過濾
        'require_debug_true': {  # django在debug模式下才輸出日誌
            '()': 'django.utils.log.RequireDebugTrue',
        },
    },
    'handlers': {  # 日誌處理方法
        'console': {  # 向終端中輸出日誌
            'level': 'INFO',
            'filters': ['require_debug_true'],
            'class': 'logging.StreamHandler',
            'formatter': 'simple'
        },
        'file': {  # 向文件中輸出日誌
            'level': 'INFO',
            'class': 'logging.handlers.RotatingFileHandler',
            'filename': os.path.join(os.path.dirname(BASE_DIR), 'logs/mall.log'),  # 日誌文件的位置
            'maxBytes': 300 * 1024 * 1024,
            'backupCount': 10,
            'formatter': 'verbose'
        },
    },
    'loggers': {  # 日誌器
        'django': {  # 定義了一個名爲django的日誌器
            'handlers': ['console', 'file'],  # 能夠同時向終端與文件中輸出日誌
            'propagate': True,  # 是否繼續傳遞日誌信息
            'level': 'INFO',  # 日誌器接收的最低日誌級別
        },
    }
}複製代碼

而後在項目目錄中創建一個logs的目錄,而後在目錄中創建一個mall.log文件。名字能夠任意起,記得很上面file中filename對應起來便可。

固然實際開發中大都是使用git來管理項目的,每一個人調試產出的log不太同樣,開發中能夠先將其加入忽略文件中。在項目文件.gitignioe中新增以下信息:

*.log複製代碼

而後在logs目錄中創建一個.gitkeep文件,保證logs目錄能被git管理。

6.配置前端靜態文件

前面提了一下項目中的html模板文件是配置在templates中,須要在項目同名子應用中創建一個templates目錄,項目中須要使用靜態文件,好比 css、images、js 等等,須要專門使用配置一個目錄。在裏面創建不一樣的目錄來存放不一樣的文件。

STATIC_URL = '/static/' # 靜態文件的路由​# 配置靜態文件加載路徑
STATICFILES_DIRS = [os.path.join(BASE_DIR, 'static')] # 在項目同名子引用中創建一個static目錄複製代碼

STATICFILES_DIRS是一個列表,這樣咱們就能夠配置多個目錄來存放靜態文件。如:

# 配置靜態文件加載路徑
STATICFILES_DIRS = [os.path.join(BASE_DIR, 'static'),os.path.join(BASE_DIR, 'static2')] 複製代碼

7.應用註冊

在項目同名目錄中,也就是setting包同級目錄中新建一個apps的包,而後進入到apps的目錄中,在終端執行以下命令,建立一個users應用。

python ../../manage.py startapp users複製代碼

而後在dev.py中註冊應用:

INSTALLED_APPS = [
    'django.contrib.admin',
    'django.contrib.auth',
    'django.contrib.contenttypes',
    'django.contrib.sessions',
    'django.contrib.messages',
    'django.contrib.staticfiles',
    # 註冊
     'mall.apps.users.apps.UsersConfig', # 用戶模塊應用
]複製代碼

下面介紹一下python中sys模塊,在dev.pyBASE_DIR下新增:

import sys

# Build paths inside the project like this: os.path.join(BASE_DIR, ...)
BASE_DIR = os.path.dirname(os.path.dirname(os.path.abspath(__file__)))
sys.path.insert(0, os.path.join(BASE_DIR, 'apps')) # 追加項目路徑複製代碼

這樣註冊應用就能簡化成以下方式了:

INSTALLED_APPS = [
    'django.contrib.admin',
    'django.contrib.auth',
    'django.contrib.contenttypes',
    'django.contrib.sessions',
    'django.contrib.messages',
    'django.contrib.staticfiles',
    # 註冊
    # 'mall.apps.users.apps.UsersConfig', # 用戶模塊應用
    'users', # 用戶模塊應用
]複製代碼

下面整理了一份django的基礎知識大綱:

相關文章
相關標籤/搜索