要通过 Gunicorn 启动 Dash 应用程序,可以按照以下步骤操作。Dash 是一个基于 Flask 的框架,因此它兼容 WSGI,可以直接与 Gunicorn 配合使用。
1. 创建 Dash 应用
确保已经安装 Dash 和 Gunicorn:
pip install dash gunicorn
示例 Dash 应用程序 (app.py
)
import dash
from dash import html
# 创建 Dash 应用
app = dash.Dash(__name__)
server = app.server # Gunicorn 使用 WSGI 应用
# 定义布局
app.layout = html.Div([
html.H1("Hello, Dash!"),
html.P("This is a Dash app running with Gunicorn.")
])
if __name__ == "__main__":
# 开发环境下使用的调试服务器
app.run_server(debug=True, host="127.0.0.1", port=8050)
2. 使用 Gunicorn 启动 Dash
Gunicorn 需要通过 Dash 的 WSGI 应用对象启动。在 Dash 中,这个 WSGI 对象是 app.server
。
启动命令:
gunicorn -b 0.0.0.0:8050 app:server
参数说明:
-b 0.0.0.0:8050
:监听所有网络接口的8050
端口(默认 Dash 使用127.0.0.1:8050
)。app:server
:app
是你的文件名(即app.py
)。server
是 Dash 应用中的 Flask WSGI 对象。
访问:
http://<your-ip>:8050
3. Supervisor 配置 Gunicorn 管理 Dash 应用
在生产环境中,可以使用 supervisor
管理 Gunicorn 和 Dash 的运行。
创建 Supervisor 配置文件
文件路径:/etc/supervisor/conf.d/dash.conf
内容如下:
[program:dash]
command=/path/to/venv/bin/gunicorn -b 0.0.0.0:8050 app:server
directory=/path/to/your/dash/project
user=www-data
autostart=true
autorestart=true
stdout_logfile=/var/log/supervisor/dash_stdout.log
stderr_logfile=/var/log/supervisor/dash_stderr.log
重启 Supervisor:
sudo supervisorctl reread
sudo supervisorctl update
sudo supervisorctl start dash
4. 使用 Nginx 反向代理 Dash 应用(可选)
为了在生产环境中更高效、安全,可以通过 Nginx 将外部流量转发到 Gunicorn 的 Dash 服务。
配置 Nginx
编辑 /etc/nginx/sites-available/dash
:
server {
listen 80;
server_name your-domain.com;
location / {
proxy_pass http://127.0.0.1:8050; # 将请求转发到 Gunicorn
proxy_set_header Host $host;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_set_header X-Forwarded-Proto $scheme;
}
}
激活配置并重新启动 Nginx:
sudo ln -s /etc/nginx/sites-available/dash /etc/nginx/sites-enabled
sudo systemctl restart nginx
5. 检查常见问题
查看 Gunicorn 日志
如果 Gunicorn 无法启动,查看错误日志:
gunicorn -b 0.0.0.0:8050 app:server --log-level debug
检查端口占用
确保 8050
端口未被占用:
sudo lsof -i:8050
查看 Supervisor 日志
如果使用 supervisor
启动 Gunicorn,查看日志:
sudo tail -f /var/log/supervisor/dash_stdout.log
sudo tail -f /var/log/supervisor/dash_stderr.log
完整流程总结
- 创建 Dash 应用,确保
app.server
暴露为 WSGI 对象。 - 使用 Gunicorn 启动 Dash:
gunicorn -b 0.0.0.0:8050 app:server
- (可选)使用
supervisor
管理 Dash 应用进程。 - (可选)通过 Nginx 提供反向代理支持。
- 检查端口占用和日志,排查运行问题。
按照以上步骤,你就可以成功通过 Gunicorn 在生产环境中运行 Dash 应用!