我正在开发一款类似的应用程序
facebook/
__init__.py
feed/
__init__.py
business.py
views.py
models/
persistence.py
user.py
chat/
__init__.py
models.py
business.py
views.py
config/
dev.py
test.py
prod.py
我想要三个环境Dev
、Test
和Production
我有以下要求:
a.(当我启动服务器python runserver.py
时,我想提到我要连接的环境——Dev
、Test
或Production
b.(CCD_ 8&Production
应该已经构建了架构,只需要连接到机器
c.(我还希望我的测试连接到sqlite db
,并创建模式,运行测试
如何以配置的方式实现这一点,这样就不必对任何与数据库相关的内容进行硬编码。
烧瓶里有好的图案吗?
目前我的runerver.py
有我不喜欢的环境的硬编码,
app = Flask(__name__)
app.config['SECRET_KEY'] = dev.SECRET_KEY
我正在寻找比更好的想法
我使用的解决方案:
#__init__.py
app = Flask(__name__)
app.config.from_object('settings')
app.config.from_envvar('MYCOOLAPP_CONFIG',silent=True)
在应用程序加载的同一级别上:
#settings.py
SERVER_NAME="dev.app.com"
DEBUG=True
SECRET_KEY='xxxxxxxxxx'
#settings_production.py
SERVER_NAME="app.com"
DEBUG=False
所以。如果环境变量MYCOOLAPP_CONFIG不存在->将只加载settings.py,这是指默认设置(对于我来说是开发服务器(
这就是"silent=True"的原因,不需要第二个配置文件,而settings.py默认用于开发,并具有通用配置键的默认值
如果除了第一个文件中的值外,还将加载任何其他settings_file,它将覆盖原始文件中的数值。(在我的示例中,DEBUG和SERVER_NAME将被覆盖,而SECRET_KEY对所有服务器保持不变(
你唯一应该自己发现的事情取决于你启动应用程序的方式
在启动ENVVAR之前,应设置MYCOOLAP_CONFIG
例如,我使用supervisor守护进程运行,在生产服务器上,我只将其放在supervisor配置文件中:
environment=MYCOOLAPP_CONFIG="/home/tigra/mycoolapp/settings_production.py"
通过这种方式,你可以轻松地管理所有的配置文件,此外,通过这种方式你可以从git或任何其他版本控制实用程序中排除这些文件
Linux的默认方式是在启动前在控制台中执行以下操作:export MYCOOLAPP_CONFIG="/home/tigra/mycoolapp/settings_production.py"
我想这就是您想要的:
http://flask.pocoo.org/docs/config/#configuring-来自文件
但也检查了烧瓶清空项目,它是具有特定环境配置的烧瓶应用的样板。
https://github.com/italomaia/flask-empty
您可以在config.py中指定您的配置,如下所示:
class Dev(Config):
DEBUG = True
MAIL_DEBUG = True
SQLALCHEMY_ECHO = True
SQLALCHEMY_DATABASE_URI = "sqlite:////tmp/%s_dev.sqlite" % project_name
这继承了可以包含默认值的Config类。从那里,main.py有从config.py文件创建flask实例的方法,manage.py决定加载哪个配置。
下面是main.py中的一个片段,这样你就明白了:
def app_factory(config, app_name=None, blueprints=None):
app_name = app_name or __name__
app = Flask(app_name)
config = config_str_to_obj(config)
configure_app(app, config)
configure_blueprints(app, blueprints or config.BLUEPRINTS)
configure_error_handlers(app)
configure_database(app)
configure_views(app)
return app
然后manage.py根据传递的命令行参数处理环境的设置,但您可以了解它的工作原理(注意,这需要flask脚本(:
from flask.ext import script
import commands
if __name__ == "__main__":
from main import app_factory
import config
manager = script.Manager(app_factory)
manager.add_option("-c", "--config", dest="config", required=False, default=config.Dev)
manager.add_command("test", commands.Test())
manager.run()
从这里,您可以从环境变量或您选择的其他方法中选择所需的Config类。
您可以创建一个"config"模块,其中包含每个环境的配置。此后,可以通过设置shell变量来指定当前运行的环境。
如果您正在init主文件中初始化flask应用程序,那么也可以在那里设置配置。这就是我设置配置的方式:
def setup_config(app):
"""Set the appropriate config based on the environment settings"""
settings_map = {'development': DevelopmentSettings,
'staging': StagingSettings,
'testing': TestingSettings,
'production': ProductionSettings}
env = environ['ENV'].lower()
settings = settings_map[env]
app.config.from_object(settings)
在运行开发服务器甚至测试之前设置环境变量可能会很麻烦,因此我使用makefile自动执行这些操作。
还可以看看烧瓶脚本http://flask-script.readthedocs.org/en/latest/.
Flask有一个名为实例文件夹的东西,这使得可以有不同的可能配置并相应地加载它们。
您可以在setting.json中拥有属性,如:
{
"production": {
"DEBUG": false,
"APPLICATION_ROOT": "/app-root",
"DB_URI": "mongodb://20.0.0.2:27017/TEST_DB",
"FTP_HOST": "20.0.0.10"
},
"development": {
"DEBUG": true,
"APPLICATION_ROOT": "/app-root",
"DB_URI": "mongodb://localhost:27017/TEST_DB",
"FTP_HOST": "20.0.0.11"
},
"test":{
"DEBUG": false,
"APPLICATION_ROOT": "/app-root",
"DB_URI": "mongodb://localhost:27017/TEST_DB",
"FTP_HOST": "20.0.0.11"
},
"local": {
"DEBUG": true,
"APPLICATION_ROOT": "/app-root",
"DB_URI": "mongodb://localhost:27017/TEST_DB",
"FTP_HOST": "20.0.0.11"
},
"staging": {
"DEBUG": false,
"APPLICATION_ROOT": "/app-root",
"DB_URI": "mongodb://localhost:27017/TEST_DB",
"FTP_HOST": "20.0.0.19"
}
}
代码:
def load_setting():
with open('setting.json', 'r') as file:
return json.load(file)[os.getenv('FLASK_ENV')]
app = Flask('TEST-APP')
app.config.update(load_setting())
确保已将环境"FLASK_ENV"添加为开发/本地/测试/生产。
export FLASK_ENV="local"