Flask CLI 抛出 'OSError: [Errno 8] Exec 格式错误'
在运行 Flask 应用时遇到以下错误:
/home/python/.virtualenvs/flask_dome/bin/python3.6 /home/python/Desktop/flask_demo_01/app.py
* 服务 Flask 应用 "app"(延迟加载)
* 环境:生产
WARNING:不要在生产环境中使用开发服务器。
使用生产 WSGI 服务器代替。
* 调试模式:已启用
* 在 http://192.168.0.140:8888/ 上运行(按 CTRL+C 退出)
* 使用 stat 重启
Traceback (最近调用最后):
File "/home/python/Desktop/flask_demo_01/app.py", line 79, 在 <module>
app.run(host='192.168.0.140',port=8888)
File "/home/python/.virtualenvs/flask_dome/lib/python3.6/site-packages/flask/app.py", line 943, 在 run
run_simple(host, port, self, **options)
File "/home/python/.virtualenvs/flask_dome/lib/python3.6/site-packages/werkzeug/serving.py", line 988, 在 run_simple
run_with_reloader(inner, extra_files, reloader_interval, reloader_type)
File "/home/python/.virtualenvs/flask_dome/lib/python3.6/site-packages/werkzeug/_reloader.py", line 332, 在 run_with_reloader
sys.exit(reloader.restart_with_reloader())
File "/home/python/.virtualenvs/flask_dome/lib/python3.6/site-packages/werkzeug/_reloader.py", line 176, 在 restart_with_reloader
exit_code = subprocess.call(args, env=new_environ, close_fds=False)
File "/usr/lib/python3.6/subprocess.py", line 267, 在 call
with Popen(*popenargs, **kwargs) as p:
File "/usr/lib/python3.6/subprocess.py", line 709, 在 __init__
restore_signals, start_new_session)
File "/usr/lib/python3.6/subprocess.py", line 1344, 在 _execute_child
raise child_exception_type(errno_num, err_msg, err_filename)
OSError: [Errno 8] Exec 格式错误:'/home/python/Desktop/flask_demo_01/app.py'
原因及解决办法:
这是 Werkzeug 0.15.0 中的一种新行为。将 Werkzeug 降级到 0.14.1。
卸载当前版本:
(flask_dome) python@ubuntu:~/Desktop/house_bjweb$ pip install Werkzeug
Requirement 已经满足:Werkzeug 在 /home/python/.virtualenvs/flask_dome/lib/python3.6/site-packages (0.15.0)
安装指定版本:
(flask_dome) python@ubuntu:~/Desktop/house_bjweb$ pip install Werkzeug==0.14.1
Collecting Werkzeug==0.14.1
下载 https://files.pythonhosted.org/packages/20/c4/12e3e56473e52375aa29c4764e70d1b8f3efa6682bef8d0aae04fe335243/Werkzeug-0.14.1-py2.py3-none-any.whl (322kB)
|████████████████████████████████| 327kB 12kB/s
安装收集到的包:Werkzeug
找到现有安装:Werkzeug 0.15.0
卸载 Werkzeug-0.15.0:
成功卸载 Werkzeug-0.15.0
成功安装 Werkzeug-0.14.1
运行成功:
/home/python/.virtualenvs/flask_dome/bin/python3.6 /home/python/Desktop/flask_demo_01/app.py
* 服务 Flask 应用 "app"(延迟加载)
* 环境:生产
WARNING:不要在生产环境中使用开发服务器。
使用生产 WSGI 服务器代替。
* 调试模式:已启用
* 在 http://192.168.0.140:8888/ 上运行(按 CTRL+C 退出)
* 使用 stat 重启
* 调试器已启用!
* 调试器 PIN:264-574-474