【Python】详解 Flask 中开发与生产环境配置的分离策略

详解 Flask 中开发与生产环境配置的分离策略

在企业级后端接口项目中,为了满足不同环境(开发和生产)的需求,我们通常需要区分不同的配置。本指南将详细介绍如何在 Flask 应用中实现这一区分。

一、配置文件

我们创建了两个配置文件:config_dev.pyconfig_prod.py

config_dev.py

python 复制代码
class ConfigDev:
    DEBUG = True
    DB_HOST = 'localhost'
    DB_USER = 'dev_user'
    DB_PASSWORD = 'dev_password'
    DB_NAME = 'dev_database'
    PORT = 5000  # 开发环境的端口

在开发配置中,我们通常开启调试模式(DEBUG = True),使用本地数据库连接信息,并设置开发环境常用的端口。

config_prod.py

python 复制代码
class ConfigProd:
    DEBUG = False
    DB_HOST = 'prod_host'
    DB_USER = 'prod_user'
    DB_PASSWORD = 'prod_password'
    DB_NAME = 'prod_database'
    PORT = 80  # 生产环境的端口

生产配置则关闭调试模式,使用生产环境的数据库连接信息,并设置适合生产环境的端口。

二、在应用中选择配置

app.py 文件中,我们根据环境变量来选择加载相应的配置。

python 复制代码
from flask import Flask
import os

# 根据环境变量选择配置
if os.environ.get('ENV') == 'PROD':
    from config_prod import ConfigProd as Config
else:
    from config_dev import ConfigDev as Config

app = Flask(__name__)
app.config.from_object(Config)

if __name__ == '__main__':
    app.run(port=app.config['PORT'])

在本地开发时,您无需设置环境变量 ENV ,应用将默认使用开发配置。而在部署到生产环境时,设置环境变量 ENVPROD ,应用将加载生产配置。

三、使用 current_app._get_current_object()

在某些情况下,您可能需要在脱离 Flask 应用上下文的函数中获取当前应用的配置。这时可以使用 current_app._get_current_object() ,但要注意必须在应用上下文内调用。示例如下:

python 复制代码
from flask import current_app

def get_database_info():
    app = current_app._get_current_object()
    db_host = app.config['DB_HOST']
    db_user = app.config['DB_USER']
    # 其他配置项的获取
    return f"数据库主机: {db_host}, 用户: {db_user}"

# 调用示例
with app.app_context():
    print(get_database_info())
相关推荐
Cabbage_acmer23 分钟前
MySQL期中考试突击!
数据库·mysql
Lu Yao_28 分钟前
Redis 缓存
数据库·redis·缓存
wu_jing_sheng041 分钟前
Python中使用HTTP 206状态码实现大文件下载的完整指南
开发语言·前端·python
程序员大雄学编程1 小时前
「用Python来学微积分」2. 函数图像的变换
python·数学·微积分
小桥流水人家哇1 小时前
性能测试单场景测试时,是设置并发读多个文件,还是设置不同的用户读不同的文件?
数据库·性能测试技巧
表示这么伤脑筋的题我不会1 小时前
Oracle 21C 部署ogg踩过的坑
数据库·oracle
你不是我我1 小时前
【Java 开发日记】MySQL 与 Redis 如何保证双写一致性?
数据库·redis·缓存
望获linux1 小时前
【实时Linux实战系列】实时 Linux 在边缘计算网关中的应用
java·linux·服务器·前端·数据库·操作系统
fredinators1 小时前
数据库专家
大数据·数据库
Q26433650232 小时前
【有源码】基于Python与Spark的火锅店数据可视化分析系统-基于机器学习的火锅店综合竞争力评估与可视化分析-基于用户画像聚类的火锅店市场细分与可视化研究
大数据·hadoop·python·机器学习·数据分析·spark·毕业设计