易于管理配置变量,与App代码分离。在开发(CI/CD)和部署(CI/CD)Django Web应用时非常有用。
项目描述
dynamic-config
在项目开始之前声明配置变量,并从环境变量或配置文件中推断。在开发(CI/CD)和部署(CI/CD)Django Web应用时非常有用。
安装
pip install dynamic-conf
功能
- 支持.env或.py文件
- 支持使用类型注解进行类型转换
- 您也不需要包含样本文件。因为Config对象可以自己生成.env.py。
- 它还会从环境变量中加载配置变量。优先顺序是环境变量>env.py
- 属性是延迟评估的。
入门
- 您需要继承Config类。
- 配置文件应定义项目所需的所有变量。
# project/conf.py
from dynamic_conf import Config, REQUIRED
class CONFIG(Config):
    """singleton to be used for configuring from os.environ and env.py"""
    # default settings
    ENV = "prod" # optional field with a default value
    DB_NAME = "db"
    DB_HOST = "127.0.0.1"
    DB_USER = "postgres"
    DB_PASS = None # even None could be given as default value
    SECRET_KEY:str # Python 3 only
    AN_SECRET_KEY = REQUIRED # Python 2 & 3
- 要创建project/env.py,只需运行并指定CONFIG类模块的路径
# you could pass environment variables or set already with export
env DB_PASS='123' dynamic-conf project/conf.py
dynamic-conf project/conf.py DB_USER='user-1' DB_PASS='123' # pass as list of key-value pair
#to filter environment variables with a prefix
env VARS_PREFIX="PROD_" dynamic-conf project/conf.py PROD_DB_USER="user-2"
用法
- 要使用配置,只需导入并使用特定的属性即可
# project/settings.py
from conf import CONFIG
DATABASES = {
    "default": {
        "ENGINE": "django.contrib.gis.db.backends.postgis",
        "HOST": CONFIG.DB_HOST,
        "NAME": CONFIG.DB_NAME,
        "USER": CONFIG.DB_USER,
        "PASSWORD": CONFIG.DB_PASSWORD,
        "PORT": "5432",
    }
}
          项目详情
下载文件
下载适用于您平台的文件。如果您不确定选择哪个,请了解有关安装包的更多信息。
源分布
         dynamic-conf-1.0.1.tar.gz  (6.8 kB 查看哈希值)
      
    构建分布
         dynamic_conf-1.0.1-py3-none-any.whl  (7.8 kB 查看哈希值)
      
    
    
       关闭
    
      
        
    
    
  
dynamic-conf-1.0.1.tar.gz的哈希值
| 算法 | 哈希摘要 | |
|---|---|---|
| SHA256 | a476970f94486b05fb81a39ea0e7f707747ee5a0b0ac60468d434d21b3e96d83 | |
| MD5 | 035142252d94cbbbab780026e43b6d51 | |
| BLAKE2b-256 | ecb60eeccf2dddbef839cd0f7bad54b873d4189bd9185fa1b69ce876d9c0c8f4 | 
    
       关闭
    
      
        
    
    
  
dynamic_conf-1.0.1-py3-none-any.whl的哈希值
| 算法 | 哈希摘要 | |
|---|---|---|
| SHA256 | 07faf442c0b4552032df9e1bc809b84cae533f7dc6290866f17028f4d2fdb1af | |
| MD5 | 464732fa969caa4f9bd22855e45fc463 | |
| BLAKE2b-256 | 7db249707ff4a2d6ec0241886da0d208dc83e89440db1966a0b71fb20bc43aa0 |