部署产品¶
本文假设你要把应用部署到一个服务器上。本文只是给出如何创建发行文件并 进行安装的概览,但是不会具体讨论使用哪种服务器或者软件。你可以在用于 开发的电脑中设置一个新的虚拟环境,以便于尝试下面的内容。但是建议不要 用于部署一个真正的公开应用。以多种不同方式部署应用的列表参见 生产部署 。
构建和安装¶
当需要把应用部署到其他地方时,需要构建一个 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
文件。工厂会读取这个文件,如果该文
件存在的话。提制生成的值到该文件中。
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 服务器和部署选项可供选择。
下面请阅读 继续开发! 。