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

环境

服务程序版本操作系统
IIS10.0Windows10
Python33.7.*Windows 10, Windows Server 2012
wfastcgi3.0.0-
Flask1.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.exeC:\pythons\python\python.exe
wfastcgi.pyC:\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,还需要安装配置并启用CGI:

参考:上线部署系列==1、Windows+IIS+wfastcgi 环境下部署 - shanked - 博客园

windows IIS部署python Flask网站_david_lee13的博客-CSDN博客

Windows Server 2016 IIS10.0+PHP(FastCGI)+MySQL环境搭建教程 | 系统运维


IIS管理器打开方式:
控制面板 > 管理工具 > internet information service(IIS管理器)

IIS管理器中查看结果:

双击打开可以看到一下内容安装成功,如果没有则后续无法执行:

添加网站

1.IIS管理器上添加一个新网站(如果是默认站点,那么可以跳过)。
我添加了一个flaskr的网站,虚拟目录指向C:\py\flask_web,端口号指定为:8001

参考:Flask + wfastcgi 在IIS可视化部署Python Web_hand2001的博客-CSDN博客

大部分百度出来的文章,这里就开始讲怎么新建一个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()函数的返回值而已。(简单点格式就是“程序文件名.app”   |   如本例程序文件名 flaskr.py)

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

=======================================

①  FastCGI 进程意外退出造成500错误
在一台新服务器上,安装新网站,之前只放至了一个网站。是服务器商配置好的,非集成环境。

添加了一个新站,路径都制定好了,但是在访问时出现了500错误。提示貌似是php的问题,但是之前的网站,运行的是discuz,一切正常,加了个新网站就报错。用phpinfo语句执行也是同样的错误。

经过一番百度,解决方法如下。

打开iis,应用程序池。选择右侧的设置应用程序池默认设置。

在弹出的窗口中,找到 “ 进程模型 > 标识  ”,点击右侧的小方块。

把值改为LocalSystem。重启IIS,即可解决。

② IIS10  FastCGI设置 模块找不到, 卸载掉 CGI模块,重新安装一遍,重启服务器。


 

  • 0
    点赞
  • 16
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值