首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何使用pyinstaller构建一个使用多个cx_oracle客户端版本的Oracle应用程序?

如何使用pyinstaller构建一个使用多个cx_oracle客户端版本的Oracle应用程序?
EN

Stack Overflow用户
提问于 2016-09-05 13:04:42
回答 1查看 704关注 0票数 0

我正在使用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)上。

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 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来验证您的配置是否也是正确的。

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/39324217

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档