烧瓶,Windows,IIS,Plotly-Dash。读取WSGI处理程序时出错

时间:2018-04-13 10:02:22

标签: python iis flask plotly plotly-dash

我希望你能帮助我解决我在Flask尝试在Windows服务器上部署plotly-dash时遇到的错误。

我使用以下指南逐字设置Flask,但我的网站在wwwroot文件夹中的位置除外: Flask on IIS

当我使用最基本的应用程序时,它工作正常,例如以下代码:

from flask import Flask
app = Flask(__name__)

@app.route("/")
def hello():
    return "Hello from FastCGI via IIS!"

if __name__ == "__main__":
    app.run()

但是如果我尝试稍微复杂的东西,比如基本的Dash演示:

import dash
import dash_core_components as dcc
import dash_html_components as html

app = dash.Dash()

app.layout = html.Div(children=[
    html.H1(children='Hello Dash'),

    html.Div(children='''
        Dash: A web application framework for Python.
    '''),

    dcc.Graph(
        id='example-graph',
        figure={
            'data': [
                {'x': [1, 2, 3], 'y': [4, 1, 2], 'type': 'bar', 'name': 'SF'},
                {'x': [1, 2, 3], 'y': [2, 4, 5], 'type': 'bar', 'name': u'Montréal'},
            ],
            'layout': {
                'title': 'Dash Data Visualization'
            }
        }
    )
])

if __name__ == '__main__':
    app.run_server(debug=True)

我收到如下错误(为了便于解释,我试图整理一下):

Error occurred while reading WSGI handler: 
Traceback (most recent call last): 
    File "C:\inetpub\wwwroot\wfastcgi.py", line 791, in main env, handler = read_wsgi_handler(response.physical_path) 
    File "C:\inetpub\wwwroot\wfastcgi.py", line 633, in read_wsgi_handler handler = get_wsgi_handler(os.getenv("WSGI_HANDLER")) 
    File "C:\inetpub\wwwroot\wfastcgi.py", line 600, in get_wsgi_handler handler = __import__(module_name, fromlist=[name_list[0][0]]) 
    File ".\app.py", line 1, in import dash 
    File "C:\Python36\lib\site-packages\dash\__init__.py", line 1, in from .dash import Dash # noqa: F401 
    File "C:\Python36\lib\site-packages\dash\dash.py", line 12, in import plotly 
    File "C:\Python36\lib\site-packages\plotly\__init__.py", line 31, in from plotly import (plotly, dashboard_objs, graph_objs, grid_objs, tools, 
    File "C:\Python36\lib\site-packages\plotly\plotly\__init__.py", line 10, in from . plotly import ( 
    File "C:\Python36\lib\site-packages\plotly\plotly\plotly.py", line 30, in from plotly import exceptions, files, session, tools, utils 
    File "C:\Python36\lib\site-packages\plotly\tools.py", line 59, in ipython_core_display = optional_imports.get_module('IPython.core.display') 
    File "C:\Python36\lib\site-packages\plotly\optional_imports.py", line 23, in get_module return import_module(name) 
    File "C:\Python36\lib\importlib\__init__.py", line 126, in import_module return _bootstrap._gcd_import(name[level:], package, level) 
    File "C:\Python36\lib\site-packages\IPython\__init__.py", line 55, in from .terminal.embed import embed 
    File "C:\Python36\lib\site-packages\IPython\terminal\embed.py", line 15, in from IPython.core.interactiveshell import DummyMod, InteractiveShell 
    File "C:\Python36\lib\site-packages\IPython\core\interactiveshell.py", line 61, in from IPython.utils import io 
    File "C:\Python36\lib\site-packages\IPython\utils\io.py", line 95, in stdin = IOStream(sys.stdin, fallback=devnull) 
    File "C:\Python36\lib\site-packages\IPython\utils\io.py", line 39, in __init__ for meth in filter(clone, dir(stream)): 
    File "C:\Python36\lib\site-packages\IPython\utils\io.py", line 38, in clone return not hasattr(self, meth) and not meth.startswith('_') 
    File "C:\Python36\lib\site-packages\IPython\utils\io.py", line 82, in closed return self.stream.closed 
    ValueError: underlying buffer has been detached StdOut: StdErr:

我已经完成了大量的谷歌搜索,并尽力解码这个错误,但我正在打砖墙。有没有人有任何想法?

根据@susodapop的建议,我删除了IPython,现在收到以下错误:

Error occurred: Traceback (most recent call last): File "C:\inetpub\wwwroot\wfastcgi.py", line 847, in main result = handler(record.params, response.start) 
TypeError: 'Dash' object is not callable StdOut: StdErr: C:\Python34\lib\site-packages\plotly\tools.py:103: UserWarning: Looks like you don't have 'read-write' permission to your 'home' ('~') directory or to our '~/.plotly' directory. 
That means plotly's python api can't setup local configuration files. No problem though! You'll just have to sign-in using 'plotly.plotly.sign_in()'. For help with that: 'help(plotly.plotly.sign_in)'. Questions? Visit https://support.plot.ly 

2 个答案:

答案 0 :(得分:0)

尝试使用wfastcgi.py wfastcgi.py及其随附的配置说明。较早版本的 system ("mode 1000"); 在尝试将二进制输出写入非二进制对象时遇到问题,这与您在此处看到的类似。

直到最近,在线使用IIS配置Flask的说明都有点令人困惑。除非您使用Azure,否则Microsoft自己的解决方案最容易配置。

答案 1 :(得分:0)

我遇到了类似的问题。这是我执行此操作的步骤:

1)确保“添加模块映射”可执行文件中的python.exe,管道和wfastcgi.py文件之间没有空格。有关说明,请参见此link。这给我带来了500错误。

2)确保您使用的是flask应用程序实例,而不是破折号应用程序实例。请参见Dash Deployment User Guide,这是通过在WSGI_HANDLER环境变量中使用app.server而不是app.app来完成的。链接中的屏幕截图来自1.。

3)最后,如果您从原始问题中得到错误,请按照注释中的指示卸载IPython。

在这三个问题之后。我将仪表板应用程序部署在IIS上。