部署产品

本文假设你要把应用部署到一个服务器上。本文只是给出如何创建发行文件并 进行安装的概览,但是不会具体讨论使用哪种服务器或者软件。你可以在用于 开发的电脑中设置一个新的虚拟环境,以便于尝试下面的内容。但是建议不要 用于部署一个真正的公开应用。以多种不同方式部署应用的列表参见 生产部署

构建和安装

当需要把应用部署到其他地方时,需要构建一个 wheel.whl )文件。 构建工作需要安装和使用 build 工具。

$ pip install build
$ python -m build --wheel

构建的文件为 dist/flaskr-1.0.0-py3-none-any.whl 。文件名由项目名 称、版本号和一些关于项目安装要求的标记组成,形如: {project name}-{version}-{python tag}-{abi tag}-{platform tag} 。

复制这个文件到另一台机器, 创建一个新的虚拟环境 ,然后用 pip 安 装这个文件。

$ pip install flaskr-1.0.0-py3-none-any.whl

Pip 会安装项目和相关依赖。

既然这是一个不同的机器,那么需要再次运行 init-db 命令,在实例文件 夹中创建数据库。

$ flask --app flaskr init-db

当 Flask 探测到它已被安装(不在编辑模式下),它会与前文不同,使用 .venv/var/flaskr-instance 作为实例文件夹。

配置密钥

在教程开始的时候给了 SECRET_KEY 一个缺省值。在产品中我们应当 设置一些随机内容。否则网络攻击者就可以使用公开的 'dev' 键来修改会 话 cookie ,或者其他任何使用密钥的东西。

可以使用下面的命令输出一个随机密钥:

$ python -c 'import secrets; print(secrets.token_hex())

'192b9bdd22ab9ed4d12e236c78afcb9a393ec15f71bbf5dc987d54727823bcbf

在实例文件夹创建一个 config.py 文件。工厂会读取这个文件,如果该文 件存在的话。提制生成的值到该文件中。

.venv/var/flaskr-instance/config.py
SECRET_KEY = '192b9bdd22ab9ed4d12e236c78afcb9a393ec15f71bbf5dc987d54727823bcbf'

其他必须的配置也可以写入该文件中。 Flaskr 只需要 SECRET_KEY 即可。

运行产品服务器

当运行公开服务器而不是进行开发的时候,不应当使用内建的开发服务器 ( flask run )。开发服务器由 Werkzeug 提供,目的是为了方便开发, 但是不够高效、稳定和安全。

替代地,应当选用一个产品级的 WSGI 服务器。例如,使用 Waitress 。首 先在虚拟环境中安装它:

$ pip install waitress

需要把应用告知 Waitree ,但是方式与 flask run 那样使用 --app 不同。需要告知 Waitree 导入并调用应用工厂来得到一个应用对象。

$ waitress-serve --call 'flaskr:create_app'

Serving on http://0.0.0.0:8080

以多种不同方式部署应用的列表参见 生产部署 。使用 Waitress 只是一个示例,选择它是因为它同时支持 Windows 和 Linux 。还有 其他许多 WSGI 服务器和部署选项可供选择。

下面请阅读 继续开发!