我正在尝试在Heroku上使用opencv,但我在服务器的日志文件中出现以下错误:
2017-10-05T23:17:08.145096+00:00 heroku[web.1]: State changed from crashed to starting
2017-10-05T23:17:19.477843+00:00 heroku[web.1]: Starting process with command `python Main.py`
2017-10-05T23:17:23.469550+00:00 heroku[web.1]: State changed from starting to crashed
2017-10-05T23:17:23.458477+00:00 heroku[web.1]: Process exited with status 1
2017-10-05T23:17:23.268234+00:00 app[web.1]: Traceback (most recent call last):
2017-10-05T23:17:23.268249+00:00 app[web.1]: File "Main.py", line 3, in <module>
2017-10-05T23:17:23.268434+00:00 app[web.1]: from MostDominantColor import get_color
2017-10-05T23:17:23.268541+00:00 app[web.1]: File "/app/utils.py", line 3, in <module>
2017-10-05T23:17:23.268435+00:00 app[web.1]: File "/app/MostDominantColor.py", line 2, in <module>
2017-10-05T23:17:23.268538+00:00 app[web.1]: import utils
2017-10-05T23:17:23.268648+00:00 app[web.1]: import cv2
2017-10-05T23:17:23.268790+00:00 app[web.1]: ImportError: libSM.so.6: cannot open shared object file: No such file or directory
2017-10-05T23:17:23.268663+00:00 app[web.1]: File "/app/.heroku/python/lib/python3.6/site-packages/cv2/__init__.py", line 9, in <module>
2017-10-05T23:17:23.268776+00:00 app[web.1]: from .cv2 import *
在__init__.py文件的第9行,有一段代码只对IDE的自动完成有用:
8 # make IDE's (PyCharm) autocompletion happy
9 from .cv2 import *
据我所知,这行在我的代码中导入cv2时出现问题,是否有办法从服务器删除该行(知道cv2库是由pip在服务器端下载的,所以我不能只是推送这样通过git编辑Heroku)
欢迎任何建议!
python : 3.6.2
opencv-python==3.3.0.10
答案 0 :(得分:3)
您必须安装一些依赖项,因为 Heroku 不会自动为您安装。
libsm6
libxrender1
libfontconfig1
libice6
注意:Aptfile 不应有任何 .txt 或任何其他扩展名。就像 档案
将编辑好的代码推送到 Github
在heroku仪表板中,
转到您的应用 --> 设置 --> 构建包 --> 添加构建包 --> https://github.com/heroku/heroku-buildpack-apt.git
复制并粘贴此链接 --> 添加构建包
部署您的应用
答案 1 :(得分:2)
这是一个依赖性问题,我需要的是安装它:
apt-get install libsm6 libxrender1 libfontconfig1
Ps:Heroku的免费帐户不包含ssh连接,因此我切换到Google Cloud Platfom并且可以正常运行。