python

基于Flask框架的Web应用部署到IIS服务器上

2020-08-22  本文已影响0人  忘了呼吸的那只猫

环境

服务程序 版本 操作系统
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管理器中配置。
这里还是直接编辑文件来的方便,且不容易出错。

<?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文件,即可使用。用模块方式,其实更方便。这种在大型项目中会用到,我这里只是单文件的简单项目部署就没有用到这种方式,但在开发过程中通常使用模块的方式。

上一篇下一篇

猜你喜欢

热点阅读