本篇文章給大家分享的是有關(guān)Django是否可以配置多個(gè)settings文件,小編覺(jué)得挺實(shí)用的,因此分享給大家學(xué)習(xí),希望大家閱讀完這篇文章后可以有所收獲,話不多說(shuō),跟著小編一起來(lái)看看吧。
成都創(chuàng)新互聯(lián)公司致力于成都網(wǎng)站設(shè)計(jì)、網(wǎng)站制作,成都網(wǎng)站設(shè)計(jì),集團(tuán)網(wǎng)站建設(shè)等服務(wù)標(biāo)準(zhǔn)化,推過(guò)標(biāo)準(zhǔn)化降低中小企業(yè)的建站的成本,并持續(xù)提升建站的定制化服務(wù)水平進(jìn)行質(zhì)量交付,讓企業(yè)網(wǎng)站從市場(chǎng)競(jìng)爭(zhēng)中脫穎而出。 選擇成都創(chuàng)新互聯(lián)公司,就選擇了安全、穩(wěn)定、美觀的網(wǎng)站建設(shè)服務(wù)!
我們僅僅處理一個(gè)單一的設(shè)置文件 settings.py文件由django-admin.py startproject命令生成。但是當(dāng)你準(zhǔn)備要進(jìn)行配置的時(shí)候,你將發(fā)現(xiàn)你需要多個(gè)配置文件以使你的開(kāi)發(fā)環(huán)境和產(chǎn)品環(huán)境相獨(dú)立。 比如,你可能不想每次在本地機(jī)器上測(cè)試代碼改變的時(shí)候?qū)EBUG從False 改為T(mén)rue。Django通過(guò)使用多個(gè)配置文件而使得這種情況很容易得到避免。
如果你想把你的配置文件按照產(chǎn)品設(shè)置和開(kāi)發(fā)設(shè)置組織起來(lái),你可以通過(guò)下面三種方法的其中一種達(dá)到這個(gè)目的。
設(shè)置成兩個(gè)全面的,彼此獨(dú)立的配置文件
設(shè)置一個(gè)基本的配置文件(比如,為了開(kāi)發(fā))和第二個(gè)(為了產(chǎn)品)配置文件,第二個(gè)配置文件僅僅從基本的那個(gè)配置文件導(dǎo)入配置,并對(duì)需要定義的進(jìn)行復(fù)寫(xiě).
使用一個(gè)單獨(dú)的配置文件,此配置文件包含一個(gè)Python的邏輯判斷根據(jù)上下文環(huán)境改變?cè)O(shè)置。
我們將會(huì)在依次解釋這幾種方式
首先,最基本的方法是定義兩個(gè)單獨(dú)的配置文件。 如果你是跟隨之前的例子做下來(lái)的,那么你已經(jīng)有了一個(gè)settings.py了,現(xiàn)在你只需要將它復(fù)制一份并命名為settings_production.py(文件名可以按照你自己的喜好定義),在這個(gè)新文件中改變DEBUG等設(shè)置。
第二種方法比較類似,但是減少了許多冗余。 作為使用兩個(gè)內(nèi)容大部分相同的配置文件的替代方式,你可以使用一個(gè)文件為基本文件,另外一個(gè)文件從基本文件中導(dǎo)入相關(guān)設(shè)定。 例如
# settings.py DEBUG = True TEMPLATE_DEBUG = DEBUG DATABASE_ENGINE = 'postgresql_psycopg2' DATABASE_NAME = 'devdb' DATABASE_USER = '' DATABASE_PASSWORD = '' DATABASE_PORT = '' # ... # settings_production.py from settings import * DEBUG = TEMPLATE_DEBUG = False DATABASE_NAME = 'production' DATABASE_USER = 'app' DATABASE_PASSWORD = 'letmein'
此處,settings_production.py 從settings.py 導(dǎo)入所有的設(shè)定,僅僅只是重新定義了產(chǎn)品模式下需要特殊處理的設(shè)置。 在這個(gè)案例中,DEBUG 被設(shè)置為False,但是我們已經(jīng)對(duì)產(chǎn)品模式設(shè)置了不同的數(shù)據(jù)庫(kù)訪問(wèn)參數(shù)。 (后者將向你演示你可以重新定義 任何 設(shè)置,并不只是象 DEBUG 這樣的基本設(shè)置。)
最終,最精簡(jiǎn)的達(dá)到兩個(gè)配置環(huán)境設(shè)定的方案是使用一個(gè)配置文件,在此配置文件中根據(jù)不同的環(huán)境進(jìn)行設(shè)置。 一個(gè)達(dá)到這個(gè)目的的方法是檢查當(dāng)前的主機(jī)名。 例如:
# settings.py import socket if socket.gethostname() == 'my-laptop': DEBUG = TEMPLATE_DEBUG = True else: DEBUG = TEMPLATE_DEBUG = False # ...
在這里,我們從python標(biāo)準(zhǔn)庫(kù)導(dǎo)入了socket 模塊,使用它來(lái)檢查當(dāng)前系統(tǒng)的主機(jī)名。 我們可以通過(guò)檢查主機(jī)名來(lái)確認(rèn)代碼是否運(yùn)行在產(chǎn)品服務(wù)器上。
一個(gè)關(guān)鍵是配置文件僅僅是包含python代碼的文件。你可以從其他文件導(dǎo)入這些python代碼,可以通過(guò)這些代碼執(zhí)行任意的邏輯判斷等操作。 如果你打算按照這種方案走下去,請(qǐng)確定這些配置文件中的代碼是足夠安全(防彈)的。 如果這個(gè)配置文件拋出任何的異常,Django都有可能會(huì)發(fā)生很嚴(yán)重的崩潰。
重命名settings.py
隨便將你的settings.py重命名為settings_dev.py或settings/dev.py或foobar.py,Django 并不在乎你的配置文件取什么名字,只要你告訴它你使用的哪個(gè)配置文件就可以了。
但是如果你真的重命名了由django-admin.py startproject 命令創(chuàng)建的settings.py文件,你會(huì)發(fā)現(xiàn)manage.py會(huì)給出一個(gè)錯(cuò)誤信息說(shuō)找不到配置文件。 那是由于它嘗試從這個(gè)文件中導(dǎo)入一個(gè)叫做settings的模塊,你可以通過(guò)修改manage.py 文件,將 import settings 語(yǔ)句改為導(dǎo)入你自己的模塊,或者使用django-admin.py而不是使用manage.py,在后一種方式中你需要設(shè)置 DJANGO_SETTINGS_MODULE 環(huán)境變量為你的配置文件所在的python 路徑.(比如'mysite.settings')。
DJANGO_SETTINGS_MODULE
通過(guò)這種方式的代碼改變后,本章的下一部分將集中在對(duì)具體環(huán)境(比如Apache)的發(fā)布所需要的指令上。 這些指令針對(duì)每一種環(huán)境都不同,但是有一件事情是相同的。 在每一種環(huán)境中,你都需要告訴Web服務(wù)器你的DJANGO_SETTINGS_MODULE是什么,這是你的Django應(yīng)用程序的進(jìn)入點(diǎn)。 DJANGO_SETTINGS_MODULE指向你的配置文件,在你的配置文件中指向你的ROOT_URLCONF,在ROOT_URLCONF中指向了你的視圖以及其他的部分。
DJANGO_SETTINGS_MODULE是你的配置文件的python的路徑 比如,假設(shè)mysite是在你的Python路徑中,DJANGO_SETTINGS_MODULE對(duì)于我們正在進(jìn)行的例子就是'mysite.settings'。
以上就是Django是否可以配置多個(gè)settings文件,小編相信有部分知識(shí)點(diǎn)可能是我們?nèi)粘9ぷ鲿?huì)見(jiàn)到或用到的。希望你能通過(guò)這篇文章學(xué)到更多知識(shí)。更多詳情敬請(qǐng)關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道。