Heroku中的Python cx_Oracle

Már*_*rte 5 python oracle heroku

我在这个问题上挣扎了一个星期.我正在尝试运行一个使用即时客户端版本11.2.0.3.0连接远程Oracle数据库的python烧瓶应用程序.

经过很多问题后,我结束了使用3个buildpacks,其中两个我需要自定义然后我可以在Heroku中安装cx_Oracle,但是当我运行代码时出现错误:

import cx_Oracle
ImportError: libaio.so.1: cannot open shared object file: No such file or directory
Run Code Online (Sandbox Code Playgroud)

好吧,这个错误有很好的记录,所以我只需要做:

$ apt-get install libaio1 libaio-dev
Run Code Online (Sandbox Code Playgroud)

但问题是如何在Heroku App中运行apt-get?使用第三个buildpack:

github.com/heroku/heroku-buildpack-apt
Run Code Online (Sandbox Code Playgroud)

其他构建包:

github.com/Maethorin/oracle-heroku-buildpack
github.com/Maethorin/heroku-buildpack-python
Run Code Online (Sandbox Code Playgroud)

配置完所有内容后,我运行了Heroku部署并在执行时遇到了同样的错误.我可以在Heroku部署日志中看到heroku-buildpack-apt它完成了它的工作,但我得到了相同的错误import cx_Oracle.顺便说一句,为了确保,我改变了我正在使用的分叉python buildpack,pip uninstall cx_Oracle在每次部署时都做了,所以我可以有一个新编译的版本.

此时,Great Internet再也无法帮助我了.在我看的任何地方,我都可以选择安装libaio.我试图在Heroku应用程序中搜索使用apt-get,但一切都指向heroku-buildpack-apt

我认为问题可能是cx_Oracle无法找到已安装的libaio并且我设置了很多Heroku App环境变量:

$ heroku config:set ORACLE_HOME=/app/vendor/oracle_instantclient/instantclient_11_2
$ heroku config:set LD_LIBRARY_PATH=/app/.apt/usr/lib/x86_64-linux-gnu:/app/vendor/oracle_instantclient/instantclient_11_2:/app/vendor/oracle_instantclient/instantclient_11_2/sdk:/lib/x86_64-linux-gnu:/usr/lib/x86_64-linux-gnu:/usr/lib:/lib
$ heroku config:set LIBRARY_PATH=/app/.apt/usr/lib/x86_64-linux-gnu:/app/vendor/oracle_instantclient/instantclient_11_2:/app/vendor/oracle_instantclient/instantclient_11_2/sdk:/lib/x86_64-linux-gnu:/usr/lib/x86_64-linux-gnu:/usr/lib:/lib
$ heroku config:set INCLUDE_PATH=/app/.apt/usr/include
$ heroku config:set PATH=/bin:/sbin:/usr/bin:/app/.apt/usr/bin
$ heroku config:set PKG_CONFIG_PATH=/app/.apt/usr/lib/x86_64-linux-gnu/pkgconfig
$ heroku config:set CPPPATH=/app/.apt/usr/include
$ heroku config:set CPATH=/app/.apt/usr/include
Run Code Online (Sandbox Code Playgroud)

编辑:我忘了提到这个:

当我运行heroku run ls -la /app/.apt/usr/lib/x86_64-linux-gnu应该安装libaio 的地方时,我得到了这个:

drwx------ 3 u32473 dyno  4096 Dec 21  2013 .
drwx------ 3 u32473 dyno  4096 Dec 21  2013 ..
-rw------- 1 u32473 dyno 16160 May  9  2013 libaio.a
lrwxrwxrwx 1 u32473 dyno    37 May  9  2013 libaio.so -> /lib/x86_64-linux-gnu/libaio.so.1.0.1
drwx------ 2 u32473 dyno  4096 May 17 16:57 pkgconfig
Run Code Online (Sandbox Code Playgroud)

但是当我跑的时候heroku run ls -l /lib/x86_64-linux-gnu/libaio.so.1.0.1那里没有文件.那么真正的问题是libaio安装在哪里?

有人可以帮我做这个工作吗?或者还有另一个很好的替代cx_Oracle?

谢谢!

Már*_*rte 0

我解决了这个问题...问题实际上是libaio.so.

我开始寻找可以安装该库的所有可能的位置。我在认为它安装的位置/app/.apt/lib/x86_64-linux-gnu而不是在其中找到它,也不在任何系统 lib 文件夹中找到它。/app/.apt/usr/lib/x86_64-linux-gnuheroku-buildpack-apt

所以我添加了这条路径LD_LIBRARY_PATH,一切正常!

全部!