Flask 使用類組織配置詳情
在實際的項目中,我們一般都會建立三個環境:開發、測試和生產環境,這三種環境會使用不同的配置組合,為瞭能方便地切換配置,我們可以為不同的環境創建不同的配置文件,但是最方便的做法是在單個配置文件中使用 Python
類來組織多個不同類別的配置。
例如下面是一個應用的配置文件 settings.py
,它包含一個基本配置類 BaseConfig
,
還有其他特定的配置類:
- 開發配置類
DevelopConfig
- 測試配置類
TestCofig
- 生產配置類
ProductConfig
這些特定配置類都繼承自基本配置類。
import logging import os class BaseConfig(object): DEBUG = True SECRET_KEY = "qwertyuiop" SQLALCHEMY_DATABASE_URI = "mysql://username:[email protected]:3306/app_db" SQLALCHEMY_TRACK_MODIFICATIONS = False REDIS_URL = "redis://:[email protected]:6379/0" LEVEL_NAME = logging.DEBUG class DevelopConfig(BaseConfig): pass class TestConfig(BaseConfig): TESTING = True SQLALCHEMY_DATABASE_URI = "mysql://username:[email protected]:3306/app_db" class ProductConfig(BaseConfig): DEBUG = False LEVEL_NAME = logging.ERROR SQLALCHEMY_DATABASE_URI = os.getenv("DATABASE_URL", "mysql://username:password@**.***.*.**:3306/app_db") config_dict = { "develop": DevelopConfig, "product": ProductConfig, "test": TestConfig }
上述代碼中,首先建立瞭一個基本配置類 BaseConfig
並初始化瞭一些配置信息,然後針對不同的環境建立瞭不同的類繼承自 BaseConfig
類,重新設置瞭不同的配置信息,例如數據庫 url
,測試環境與開發環境不同,生產環境優先從環境變量中獲取。
然後,創建瞭一個字典來存儲配置名稱和配置類的映射,相當於提供瞭一個配置信息的訪問入口,可以根據指定的配置名稱來獲取對應的配置類。
編寫好瞭配置文件,我們在應用主程序中創建 Flask
實例 app 時,就可以使用後app.config.from_object()
方法加載配置,
例如:
from settings import config_dict app = Flask(__name__) config_name = os.getenv('CONFIG_NAME', 'develop') app.config.from_object(config_dict[config_name])
首先從配置文件中導入配置名稱和配置類的映射字典 config_dict
,從環境變量 CONFIG_NAME
讀取配置名稱,然後通過app.config.from_object()
方法加載指定配置信息,如果沒有讀取到 CONFIG_NAME
,默認使用 develop
,對應的配置類即 DevelopmentConfig
。
Flask
支持多種方式加載配置信息,除瞭上述的從 Python 類中加載,還支持 從 JSON 文件中加載、從 py 文件中加載等,app.config類提供瞭不同的方法來加載不同格式的配置文件,還是比較靈活的。
到此這篇關於 Flask
使用類組織配置詳情的文章就介紹到這瞭,更多相關 Flask 使用類組織配置內容請搜索WalkonNet以前的文章或繼續瀏覽下面的相關文章希望大傢以後多多支持WalkonNet!
推薦閱讀:
- flask-SQLALchemy連接數據庫的實現示例
- python框架flask知識總結
- Flask-Sqlalchemy的基本使用詳解
- Flask框架debug與配置項的開啟與設置詳解
- Pyhon Flask框架:第一個Flask程序