前言

一个项目会涉及到开发/生产/测试环境不同的运行环境,不同环境配置参数会不太一样,比如数据库的配置,开发环境和生成环境数据库就不一样。
配置参数直接写的config.py 文件就无法区分开发/生成环境了。

环境配置

配置参数直接写的config.py 文件就无法区分开发/生成环境了。然后你只要增加一个独立的 config.py 文件并导出 ​​YOURAPPLICATION_SETTINGS=/path/to/config.py​​​ 即可。
当然还有其他方法可选, 例如可以使用导入或子类。

class Config(object):
DEBUG = False
TESTING = False
DATABASE_URI = 'sqlite:///:memory:'

class ProductionConfig(Config):
DATABASE_URI = 'mysql://[email protected]/foo'

class DevelopmentConfig(Config):
DEBUG = True

class TestingConfig(Config):
TESTING = True

如果要使用这样的方案,那么必须使用 from_object():

app.config.from_object('configmodule.ProductionConfig')

注意 from_object() 不会实例化类对象。如果要操作已经实 例化的类,比如读取一个属性,那么在调用 from_object() 之前应当先实例化这个类:

from configmodule import ProductionConfig
app.config.from_object(ProductionConfig())

# Alternatively, import via string:
from werkzeug.utils import import_string
cfg = import_string('configmodule.ProductionConfig')()
app.config.from_object(cfg)

在你的配置类中,实例化配置对象时允许使用 @property

class Config(object):
"""Base config, uses staging database server."""
DEBUG = False
TESTING = False
DB_SERVER = '192.168.1.56'

@property
def DATABASE_URI(self): # Note: all caps
return 'mysql://[email protected]{}/foo'.format(self.DB_SERVER)

class ProductionConfig(Config):
"""Uses production database server."""
DB_SERVER = '192.168.19.32'

class DevelopmentConfig(Config):
DB_SERVER = 'localhost'
DEBUG = True

class TestingConfig(Config):
DB_SERVER = 'localhost'
DEBUG = True
DATABASE_URI = 'sqlite:///:memory:'

配置的方法多种多样,由你定度。以下是一些好的建议:

  • 在版本控制中保存一个缺省配置。要么在应用中使用这些缺省配置,要么先导入 缺省配置然后用你自己的配置文件来重载缺省配置。
  • 使用一个环境变量来切换不同的配置。这样就可以在 Python 解释器外进行切换, 而根本不用改动代码,使开发和部署更方便,更快捷。如果你经常在不同的项目 间切换,那么你甚至可以创建代码来激活 virtualenv 并导出开发配置。
  • 在生产应用中使用 fabric 之类的工具,向服务器分别传送代码和配置。更 多细节参见 使用 Fabric 部署 方案。