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!

推薦閱讀: