Python工程配置需分环境、可覆盖、易维护、防泄露:通过环境变量动态加载dev/test/prod配置,敏感信息外置到.gitignore的.env或系统变量,用Pydantic Settings结构化校验,支持热更新与文档化说明。
Python工程中配置文件不是简单写个config.py就完事,关键在于分环境、可覆盖、易维护、不泄露敏感信息。核心思路是:配置与代码分离、层级化管理、运行时按需加载。
避免用if 硬编码判断,而是通过环境变量指定当前环境:
DEBUG:
settings.py),只负责读取ENV环境变量,动态导入对应模块:from configs.prod import Settings
configs/dev.py, configs/prod.py)继承基类,只覆盖差异项,比如数据库URL、日志级别、是否启用调试模式ENV=prod python app.py,或在Docker中设ENV=prod
密码、密钥、API Token等绝不能写死在代码或Git仓库里:
.env(已加入.gitignore),内容如:DATABASE_PASSWORD=abc123
config("DATABASE_PASSWORD", default="")安全读取,未提供时抛异常或回退默认值.env仅用于本地开发),部署时由运维注入真实凭证告别字典嵌套和手动类型转换,用pydantic.BaseSettings自动完成类型解析、默认值填充、字段校验:
Field(default=...),支持从环境变量、.env、JSON/YAML文件多源加载redis_url: str = Field(default="redis://localhost:6379/0"),若环境变量有REDIS_URL则自动覆盖Settings()实例化,失败直接报错(如端口非int、URL格式错误),提前暴露问题部分场景需要运行时调整配置(如限流阈值、开关策略),不重启服务:
watchdog监听config.yaml文件变更,触发重新加载(适合内部工具类服务)不复杂但容易忽略:所有配置项要有明确文档说明(放在配置类docstring或README里),包括用途、是否必需、默认值、生效范围。配置即契约,团队协作的基础。