使用 Numpy、Pandas 等在 Python 3.7+ 中使用 wfastcgi 在 IIS 上部署 Python Flask 应用程序

问题描述

当使用 wfastcgi 在 IIS 上部署 python 3.7+ Flask 或 Dash 应用程序时,有很多很棒的教程可以让你好工作程序工作,例如

https://medium.com/@bilalbayasut/deploying-python-web-app-flask-in-windows-server-iis-using-fastcgi-6c1873ae0ad8

这个过程对我来说失败了,而对于其他用户来说似乎是

Can't get dash app run on IIS with flask server

How to deploy python flask application in conda base environment on IIS server?

其他软件包开始混入的时候,例如 Numpy、Pandas、Dash、Plotly Express 等。

抛出的错误往往取决于包,但通常类似于一大块测试,看起来像下面以 Error occurred while reading WSGI handler 开头的错误,并具有 Dll 加载失败或缺少组件等内容。

Error occurred while reading WSGI handler: Traceback (most recent call last): File "C:\ProgramData\Anaconda3\envs\dash_search_app\lib\site-packages\wfastcgi.py",line 791,in main env,handler = read_wsgi_handler(response.physical_path) File "C:\ProgramData\Anaconda3\envs\dash_search_app\lib\site-packages\wfastcgi.py",line 633,in read_wsgi_handler handler = get_wsgi_handler(os.getenv("WSGI_HANDLER")) File "C:\ProgramData\Anaconda3\envs\dash_search_app\lib\site-packages\wfastcgi.py",line 616,in get_wsgi_handler raise ValueError('"%s" could not be imported%s' % (handler_name,last_tb)) ValueError: "dashapp.server" could not be imported: Traceback 
(most recent call last): File "C:\ProgramData\Anaconda3\envs\dash_search_app\lib\site-packages\wfastcgi.py",line 600,in get_wsgi_handler handler = __import__(module_name,fromlist=[name_list[0][0]]) File ".\dashapp.py",line 3,in from flaskapp import app File ".\flaskapp\__init__.py",line 67,in register_dashapps(app) File ".\flaskapp\__init__.py",line 19,in register_dashapps from flaskapp.dashapp_searchtool.layout import layout File ".\flaskapp\dashapp_searchtool\layout.py",line 30,in import pandas as pd File "C:\ProgramData\Anaconda3\envs\dash_search_app\lib\site-packages\pandas\__init__.py",line 17,in "Unable to import required dependencies:\n" + "\n".join(missing_dependencies)
 ImportError: Unable to import required dependencies: numpy: IMPORTANT: PLEASE READ THIS FOR ADVICE ON HOW TO SOLVE THIS ISSUE! Importing the numpy c-extensions failed. - 
 Try uninstalling and reinstalling numpy. - If you have already done that,then: 1. Check that you expected to use Python3.7 from "C:\ProgramData\Anaconda3\envs\dash_search_app\python.exe",and that you have no directories in your PATH or PYTHONPATH that can interfere with the Python and numpy version "1.17.3" you're trying to use. 2. If (1) looks fine,you can open a new issue at https://github.com/numpy/numpy/issues. Please include details on: - how you installed Python 
 - how you installed numpy - your operating system - whether or not you have multiple versions of Python installed - if you built from source,your compiler versions and 
 ideally a build log - If you're working with a numpy git repository,try `git clean -xdf` (removes all files not under version control) and rebuild numpy. Note: 
 this error has many possible causes,so please don't comment on an existing issue about this - open a new one instead. Original error was: DLL load failed: 
 The specified module could not be found. StdOut: StdErr: C:\ProgramData\Anaconda3\envs\dash_search_app\lib\site-packages\flask_sqlalchemy\__init__.py:794: 
 FSADeprecationWarning: SQLALCHEMY_TRACK_MODIFICATIONS adds significant overhead and will be disabled by default in the future. Set it to True or False to suppress this warning.

最常见的建议是降级到 python 3.6,但这并非适用于每个项目。

我已经回答了我的解决方案,以防其他人可能有同样的问题,因为我的谷歌搜索时间没有导致我找到解决方案。

解决方法

对我来说,这归结为权限问题。我的第一个猜测是环境没有正确注册,但实际上是IIS没有权限访问环境的所有依赖项。

我如何解决这个问题是导航到我的 Anaconda3 文件夹,右键单击并选择属性。在属性窗口中,我导航到安全选项卡并单击编辑

Security Tab

然后我点击“添加”以添加用户并显示以下窗口

Select Users

在对象类型下,我选择了所有选项,位置我选择了顶级位置。

在对象名称下我写了 iis apppool 例如,对于名为 app 的 IIS 站点,它将是 iis apppool\app

然后我单击检查名称以确保可以找到该应用程序,然后继续单击确定并应用。

添加权限后,IIS 站点可以访问所有必需的 dll 等,并且应用程序正常运行

相关问答

依赖报错 idea导入项目后依赖报错,解决方案:https://blog....
错误1:代码生成器依赖和mybatis依赖冲突 启动项目时报错如下...
错误1:gradle项目控制台输出为乱码 # 解决方案:https://bl...
错误还原:在查询的过程中,传入的workType为0时,该条件不起...
报错如下,gcc版本太低 ^ server.c:5346:31: 错误:‘struct...