我创建了一个python-flask
应用程序,该应用程序托管在heroku上。我在python中使用了PIL
图像库。我无法在heroku实例中安装PIL
。
我尝试了以下方法。
在PIL=1.1.7
中添加了requirements.txt
在这里我得到了例外
Some externally hosted files were ignored (use --allow-external PIL to allow).
heroku run pip install PIL --allow-unverified=PIL --app=nava-app
这有助于安装PIL
我收到了成功安装的消息。
Successfully installed PIL
Cleaning up...
但是,在我推送了最新的代码之后,import error
获得了PIL
。我已通过命令heroku logs --app=nava-app
附加了下面的日志文件。
2014-08-07T09:54:28.997111+00:00 app[web.1]: worker.init_process()
2014-08-07T09:54:28.997112+00:00 app[web.1]: File "/app/.heroku/python/lib/python2.7/site-packages/gunicorn/workers/base.py", line 100, in init_process
2014-08-07T09:54:28.997113+00:00 app[web.1]: self.wsgi = self.app.wsgi()
2014-08-07T09:54:28.997115+00:00 app[web.1]: File "/app/.heroku/python/lib/python2.7/site-packages/gunicorn/app/base.py", line 103, in wsgi
2014-08-07T09:54:28.997116+00:00 app[web.1]: self.callable = self.load()
2014-08-07T09:54:28.997117+00:00 app[web.1]: File "/app/.heroku/python/lib/python2.7/site-packages/gunicorn/app/wsgiapp.py", line 25, in load
2014-08-07T09:54:28.997118+00:00 app[web.1]: return util.import_app(self.app_uri)
2014-08-07T09:54:28.997120+00:00 app[web.1]: File "/app/.heroku/python/lib/python2.7/site-packages/gunicorn/util.py", line 372, in import_app
2014-08-07T09:54:28.997121+00:00 app[web.1]: __import__(module)
2014-08-07T09:54:28.997122+00:00 app[web.1]: File "/app/app.py", line 5, in <module>
2014-08-07T09:54:28.997123+00:00 app[web.1]: from test import draw
2014-08-07T09:54:28.997125+00:00 app[web.1]: File "/app/test.py", line 10, in <module>
2014-08-07T09:54:28.997127+00:00 app[web.1]: ImportError: No module named PIL
2014-08-07T09:54:28.997126+00:00 app[web.1]: from PIL import ImageFont
2014-08-07T09:54:28.997135+00:00 app[web.1]: 2014-08-07 09:54:28 [7] [INFO] Worker exiting (pid: 7)
2014-08-07T09:54:29.421102+00:00 app[web.1]: 2014-08-07 09:54:29 [2] [INFO] Shutting down: Master
2014-08-07T09:54:29.421211+00:00 app[web.1]: 2014-08-07 09:54:29 [2] [INFO] Reason: Worker failed to boot.
2014-08-07T09:54:31.583231+00:00 heroku[router]: at=error code=H10 desc="App crashed" method=GET path="/" host=nava-app.herokuapp.com request_id=b1f72038-5c9c-4680-801e-8f6a87ab8829 fwd="103.6.158.181" dyno=web.1 connect=5000ms service= status=503 bytes=
2014-08-07T09:54:30.607109+00:00 heroku[web.1]: State changed from starting to crashed
2014-08-07T09:54:27.580747+00:00 heroku[web.1]: Starting process with command `gunicorn app:app --log-file -`
2014-08-07T09:54:30.594821+00:00 heroku[web.1]: Process exited with status 3
2014-08-07T09:54:41.551284+00:00 heroku[router]: at=error code=H10 desc="App crashed" method=GET path="/favicon.ico" host=nava-app.herokuapp.com request_id=97b28fa4-e082-4887-8b5c-d088d006e569 fwd="103.6.158.181" dyno= connect= service= status=503 bytes=
即使我曾尝试将PIL python模块作为我的应用程序的一部分导入,例如显示imaging C library not installed
你能帮我在heroku实例中安装PIL吗?
答案 0 :(得分:4)
要使用C依赖项安装Pillow和其他库,一个选项是使用conda buildpack。 Heroku在他们的文档中建议:Python C Dependencies buildpack可用here。
文档提供了执行此操作的两个步骤。
创建应用程序时使用conda build pack。
heroku create --buildpack https://github.com/kennethreitz/conda-buildpack.git
heroku create --buildpack https://github.com/kennethreitz/conda-buildpack.git
如果要将其与现有应用程序一起使用,请改用以下内容。
heroku config:添加BUILDPACK_URL = https://github.com/kennethreitz/conda-buildpack.git
完成这些步骤后,可以正常部署应用程序。