基于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/
找一个可执行的文件下载。部署端的32bit64bit版本应该和你开发端一致。经过测试,发现部分package是有不兼容的情况。

我这里就安装到C:\pythons\python下,方便处理,也可以避免windows10的文件权限问题。默认是安装到usersappData目录的,很麻烦。

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应用,可以利用上述参数进行配置且使用IISfastCGI已经配置好的脚本解释器。
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管理器中配置。
这里还是直接编辑文件来的方便,且不容易出错。



    
       
        
            
        
    
    
    
        
        
        
        
        
        
    

WSGI_HANDLER参数说明

根据wfastcgi 3.0.0中的说明,这个参数的概念:执行程序的入口。
由于大部分flask的示例都是单文件,且简单如下:

app = Flask(__name__)

因此,这里只要配置__name__.app即可,其实就是执行某个py文件中的app变量,而这个app变量为Flask()函数的返回值而已。

如果使用了模块的方式,在__init__.py中有一个函数来创建app。因此配置的值就是:flaskr.create_app(),不需要任何的管理或启动py文件,即可使用。用模块方式,其实更方便。这种在大型项目中会用到,我这里只是单文件的简单项目部署就没有用到这种方式,但在开发过程中通常使用模块的方式。

你可能感兴趣的:(基于Flask框架的Web应用部署到IIS服务器上)