基于Flask框架的Web应用部署到IIS服务器上
环境
服务程序 | 版本 | 操作系统 |
---|---|---|
IIS | 10.0 | Windows10 |
Python3 | 3.7.* | Windows 10, Windows Server 2012 |
wfastcgi | 3.0.0 | - |
Flask | 1.1 | - |
基本原理
通过配置桥接,将IIS
的请求利用wfastcgi
功能,启动flask
框架开发的程序来做响应(wfastcgi
有点类似于部署在Nginx
上时用的WSGi
)。其中,关键一点就是IIS
中配置的网站需要一个fastcgi
的配置,指定python.exe
作为cgi
程序,指定wfastcgi.py
作为脚本执行。
即配置web.config
完成这个桥接设定。
环境部署
1.安装Python3
经过反复测试,如果windows
上安全Python3
,一定要安装自定义目录,且勾选all users
选项。
一开始测试时候,一口气next
下去,无论如何都不好用,总是报错fastcgi
错误或者500
,后来重新安装Python
,并指定开放的目录才解决。应该是fastcgi
的配置需要执行权限导致的。
python3.7
下载地址:https://www.python.org/downloads/release/python-372/
找一个可执行的文件下载。部署端的32bit
或64bit
版本应该和你开发端一致。经过测试,发现部分package
是有不兼容的情况。
我这里就安装到C:\pythons\python
下,方便处理,也可以避免windows10
的文件权限问题。默认是安装到users
的appData
目录的,很麻烦。
2.安装 Flask 极其依赖包
pip install flask
注意:这里只是我简单的演示,自己可以根据项目的环境批量安装,可以在线安装也可以离线安装,个人建议在线安装,以为在线安装会自动安装相关的依赖包,离线安装,依赖包安装的顺序出错都有可能导致安装失败。
3.安装 wfastcgi
pip install wfastcgi
目前最新版本是3.0,一般会默认安装最新的
4.将项目源码拷贝到你喜欢的文件夹
这里罗列一下我的路径:
内容 | 目录 |
---|---|
python.exe | C:\pythons\python\python.exe |
wfastcgi.py | C:\pythons\python\Lib\site-packages\wfastcgi.py |
flaskr项目 | C:\py\flask_web |
向IIS注册wfastcgi功能
根据wfastcgi 3.0.0中的说明,需要启用功能。其实实际就是IIS
中增加一个fastCgi
的设置。
使用管理员权限的cmd
执行:
wfastcgi-enable
注意:这里是要用管理员权限打开cmd
控制台,wfastcgi
只需要启动一次,以后重启服务器他都会自动开启
启动成功之后
可以看到执行之后,已经提示了IIS
的配置结果。并且给出了配置参数:
C:\pythons\python\python.exe|C:\pythons\python\Lib\site-packages\wfastcgi.py
说明:
can now be used as a FastCGI script processor
这个是重点理解的地方。
也就是说,可以添加一个新网站,这个网站如果要使用wfastcgi
连接flask
应用,可以利用上述参数进行配置且使用IIS
中fastCGI
已经配置好的脚本解释器。
IIS
管理器打开方式:
控制面板 > 管理工具 > internet information service(IIS管理器)
在IIS
管理器中查看结果:
双击打开可以看到一下内容安装成功,如果没有则后续无法执行:
添加网站
1.IIS
管理器上添加一个新网站(如果是默认站点,那么可以跳过)。
我添加了一个flaskr的网站,虚拟目录指向C:\py\flask_web
,端口号指定为:8001
大部分百度出来的文章,这里就开始讲怎么新建一个web.config,最好使用IIS管理器帮我们新建一个,自己不需要动手。免得出错。
2.选中新建的网站,双击处理程序映射
3.添加一个映射程序模块:
4.配置模块:
可执行文件配置中的内容,就是FastCGI设置中的提示的参数内容:C:\pythons\python\python.exe|C:\pythons\python\Lib\site-packages\wfastcgi.py
配置请求限制为 *
:
点击请求限制,把默认的勾去掉
确定后,系统会配置一个web.config
放入项目目录下。
配置项目
即对web.config
做详细处理。这里可以手工,也可以在IIS
管理器中配置。
这里还是直接编辑文件来的方便,且不容易出错。
<?xml version="1.0" encoding="UTF-8"?>
<configuration>
<system.webServer>
<!-- handlers在4.3.2步骤中配置好,IIS管理器生成,不要手工修改 -->
<handlers>
<add name="flaskr" path="*" verb="*" modules="FastCgiModule" scriptProcessor="C:\pythons\python\python.exe|C:\pythons\python\Lib\site-packages\wfastcgi.py" resourceType="Unspecified" />
</handlers>
</system.webServer>
<!-- appSettings节点需要手工添加 -->
<appSettings>
<!-- 2个必须要有的参数:
@WSGI_HANDLER:fastCGI获得请求后调用的flask应用入口。
@PYTHONPATH: 执行整个应用的项目目录
-->
<add key="WSGI_HANDLER" value="flaskr.app" />
<!-- pythonpath这个参数,如果你设置了全局变量这个参数可以不用写,这个路径一定不能有汉字,不然访问会报500的错误 -->
<add key="PYTHONPATH" value="C:\py\flask_web" />
<!-- 可选参数, 我这里就配置一个日志文件,其他应该参考 https://pypi.org/project/wfastcgi/ -->
<add key="WSGI_LOG" value="C:\xlog\flaskr_web.log" />
</appSettings>
</configuration>
WSGI_HANDLER参数说明
根据wfastcgi 3.0.0中的说明,这个参数的概念:执行程序的入口。
由于大部分flask
的示例都是单文件,且简单如下:
app = Flask(__name__)
因此,这里只要配置__name__.app
即可,其实就是执行某个py文件中的app变量,而这个app
变量为Flask()
函数的返回值而已。
如果使用了模块的方式,在__init__.py
中有一个函数来创建app。因此配置的值就是:flaskr.create_app()
,不需要任何的管理或启动py文件,即可使用。用模块方式,其实更方便。这种在大型项目中会用到,我这里只是单文件的简单项目部署就没有用到这种方式,但在开发过程中通常使用模块的方式。