内部服务器错误:AWS Elastic Beanstalk上的Flask上的Dash

时间:2018-05-22 18:09:29

标签: python amazon-web-services flask elastic-beanstalk

NB: Dash是一个python包,用于通过plotly(网站here)构建仪表板。 Flask是一个用于构建python Web框架的python包(网站here和AWS教程here)。我正在使用python 3.6,所有包版本都可以在requirements.txt

中看到

问题:在我的AWS EB上启动我的Dash应用程序时出错。

当我在127.0.0.1:8050本地运行时,我的短跑工作。但是当我$ eb deploy时,我会在我的AWS EB URL上看到这个:

  

内部服务器错误

     

服务器遇到内部错误或配置错误,无法完成您的请求。

     

请与root @ localhost上的服务器管理员联系,告知他们此错误发生的时间以及您在此错误发生之前执行的操作。

     

服务器错误日志中可能提供了有关此错误的更多信息。

我的文件结构是这样的(其中eb-flask是我的烧瓶目录):

~/AWS/servers/flask-s
  |-- eb-virt                   }
  |    |-- bin                  }
  |    |-- include              } virtualenv files etc
  |    |-- lib                  }
  |    `-- pip-selfcheck.json   }
  |
  |-- eb-flask              <--- where I ran eb init
  |    |-- application.py
  |    |-- requirements.txt
  |    |-- .gitignore
  |    |-- .elasticbeanstalk
  `         `-- config.yml

使用$ eb config时:

aws:elasticbeanstalk:container:python:
  NumProcesses: '1'
  NumThreads: '15'
  StaticFiles: /static/=static/
  WSGIPath: application.py

我的application.py代码几乎从https://dash.plot.ly/deployment解除了测试。

import flask
import os
import dash
import dash_core_components as dcc
import dash_html_components as html

#app = dash.Dash(_name_)
#server = app.server

server = flask.Flask(_name_)
application = dash.Dash(_name_, server=server)

application.css.append_css({"external_url": "https://codepen.io/chriddyp/pen/bWLwgP.css"})

application.layout = html.Div([
    html.H2('Hello World'),
    dcc.Dropdown(
        id='dropdown',
        options=[{'label': i, 'value': i} for i in ['LA', 'NYC', 'MTL']],
        value='LA'
    ),
    html.Div(id='display-value')
])

@application.callback(dash.dependencies.Output('display-value', 'children'),
              [dash.dependencies.Input('dropdown', 'value')])
def display_value(value):
return 'You have selected "{}"'.format(value)

if _name_ == '_main_':
    application.run_server(debug=True)
#app.run_server()

requirements.txt显然是pip冻结。在这一点上,它只是烧瓶,破折号和图表所需的包装:

certifi==2018.4.16
chardet==3.0.4
click==6.7
dash==0.21.1
dash-core-components==0.22.1
dash-html-components==0.10.1
dash-renderer==0.12.1
decorator==4.3.0
Flask==1.0.2
Flask-Compress==1.4.0
gunicorn==19.8.1
idna==2.6
ipython-genutils==0.2.0
itsdangerous==0.24
Jinja2==2.10
jsonschema==2.6.0
jupyter-core==4.4.0
MarkupSafe==1.0
nbformat==4.4.0
numpy==1.14.3
pandas==0.23.0
plotly==2.6.0
python-dateutil==2.7.3
pytz==2018.4
requests==2.18.4
six==1.11.0
traitlets==4.3.2
urllib3==1.22
Werkzeug==0.14.1

服务器端显然是错误的。当我运行(eb-virt) $ python application.py时,我可以在本地访问该网站。我从HTTP GET获得此响应:

(eb-virt): eb-flask $ python application.py 
 * Serving Flask app "application" (lazy loading)
 * Environment: production
   WARNING: Do not use the development server in a production environment.
   Use a production WSGI server instead.
 * Debug mode: on
 * Running on http://127.0.0.1:8050/ (Press CTRL+C to quit)
 * Restarting with stat
 * Debugger is active!
 * Debugger PIN: 190-847-760
127.0.0.1 - - [22/May/2018 18:41:30] "GET / HTTP/1.1" 200 -
127.0.0.1 - - [22/May/2018 18:41:31] "GET /_dash-layout HTTP/1.1" 200 -
127.0.0.1 - - [22/May/2018 18:41:31] "GET /_dash-dependencies HTTP/1.1" 200 -
127.0.0.1 - - [22/May/2018 18:41:31] "POST /_dash-update-component HTTP/1.1" 200 -
127.0.0.1 - - [22/May/2018 18:41:31] "GET /favicon.ico HTTP/1.1" 200 -

然而,当我$ eb deploy时,我收到上述内部服务器错误。我感谢任何帮助。

当我enable logging时,我在本地获得application.logger.addHandler(handler) AttributeError: 'Dash' object has no attribute 'logger'。在部署时,日志文件中没有附加错误,它只是保持空白。

2 个答案:

答案 0 :(得分:0)

我认为问题在于application.run_server(debug=True)方法将localhost作为默认主机。这意味着该应用程序已部署到127.0.0.1,并且您只能从运行该应用程序的计算机内部对其进行访问。这解释了为什么您只能在本地访问该应用程序(无论是从计算机还是在实例内部)。在部署到Elastic Beanstalk时,您需要将主机指定为0.0.0.0-所有IP地址(不建议在生产环境中部署debug=True!)

if __name__ == '__main__':
    app.run_server(host="0.0.0.0")

检查this GitHub示例Flask应用程序Beanstalk部署。

答案 1 :(得分:0)

我认为“ application”这个名称有些混乱 这为我工作: 应用程序= flask.Flask(名称

app = dash.Dash(__name__, external_stylesheets=external_stylesheets,server=application)