我正在使用cx_Oracle (v5)和Pyinstaller在Python语言中构建一个应用程序来打包和分发该应用程序。在构建和打包应用程序时,我安装了Oracle12c客户端。但是,当我将其部署到安装了11g客户端的计算机上时,它似乎无法工作。我收到消息"Unable to Oracle environment handle“。我假设这是因为应用程序是用Pyinstaller打包的,而我的ORACLE_HOME指向一个12c客户机。我知道我的cx_Oracle是基于11g和12库构建的。所以,我想知道如何使用Pyinstaller部署应用程序,以便它可以在安装了11或12c客户端库的情况下运行?
顺便说一句,我是在Linux (debian/mint17.2)上构建的,然后部署到Linux (CentOS 7)上。
发布于 2016-09-06 21:07:34
错误"Unable to something environment handle“表示您的Oracle配置有问题。检查您正在使用的libclntsh.so文件。最简单的方法是在PyInstaller与可执行文件捆绑在一起的cx_Oracle模块上使用ldd命令。然后检查是否由于将环境变量ORACLE_HOME设置为不同的客户机而导致冲突!
如果PyInstaller在打包过程中拾取了libclntsh.so文件,您需要告诉它停止这样做。目标机器上必须有一个Oracle客户端(完整客户端或简单得多的即时客户端),而不仅仅是一个文件(libclntsh.so)。
您还可以通过在目标机器上使用cx_Oracle.so模块建立连接来验证您的配置是否正确--独立于您的应用程序。如果这不起作用,或者您由于某种原因没有安装Python,您还可以使用SQL*Plus来验证您的配置是否也是正确的。
https://stackoverflow.com/questions/39324217
复制相似问题