gpt4 book ai didi

python - 如何让 cx_Oracle 在 64 位 Itanium Windows 上运行?

转载 作者:可可西里 更新时间:2023-11-01 09:35:56 26 4
gpt4 key购买 nike

我在同时运行 64 位 Oracle 10.2 的 64 位 Itanium 服务器上运行 Windows Server 2003,我想为 Python 2.5 安装 cx_Oracle。我之前在 Windows 和 Linux 上多次使用过 cx_Oracle,我之前也在这些平台的 32 位版本上编译过它,但我从未尝试过 IA64 编译。

http://cx-oracle.sourceforge.net/ 处没有任何 cx_Oracle 的二进制构建是 64 位的,我在尝试运行 import cx_Oracle 时安装其中任何一个后都出现错误,所以我认为要做的事情是从源代码编译它。

当运行 python setup.py build 时,我得到一个错误,即 Python 是用 Visual Studio 2003 构建的,我需要一些可以生成兼容二进制文件的东西。我有 Visual Studio 2005,由于链接到 C 标准库的不同版本,并且可能还有其他原因,它显然不符合要求。不幸的是,Visual Studio 2003 不再提供下载,我不确定从哪里获得它。

所以我从 http://sourceforge.net/projects/mingw/files/ 下载 MinGW但这也仅以 32 位形式提供。无论如何,我继续试一试,但它在编译期间给了我一个关于我链接的 Oracle DLL 文件格式无效的错误。

在这一点上,我有很多选择,但我不确定该把我的努力放在哪里:

  1. 我可以从 http://sourceforge.net/projects/mingw-w64/ 下载 64 位 MinGW并尝试使用它,除了它似乎只能作为源代码使用,所以我必须编译编译器,可能使用 Visual Studio 2005。

  2. 我可以尝试使用 Python 的 x86 32 位版本,然后从 http://www.oracle.com/technology/software/tech/oci/instantclient/htdocs/winsoft.html 下载 Oracle Instant Client SDK然后用它来构建 cx_Oracle。我可能必须将我的 ORACLE_HOME 设置为客户端,这样它就不会尝试链接 64 位服务器 DLL,但这似乎可行。

  3. 我可以尝试使用 Visual Studio 2005 从源代码编译 Python 本身,这样我就可以使用 Visual Studio 2005 构建 cx_Oracle 而不必担心二进制兼容性问题。我已经在 Linux 上多次从源代码编译 Python 并且从未遇到过任何问题,所以我相信它在 Windows 上也一样简单。

  4. 我可以尝试弄清楚如何使 Visual Studio 2005 链接到正确的 DLL,从而以这种方式生成兼容的二进制文件而不需要 Visual Studio 2003。直觉上,Visual Studio 似乎应该能够生成兼容的二进制文件使用旧版本本身,但我几乎所有的编译器经验都是使用 gcc,所以我真的不知道。

我真的不知道该把我的精力放在哪里。有没有人对下一步去哪里有任何建议?如果有帮助,我可以复制/粘贴我收到的一些特定错误消息。

我特别想听听任何曾经让 cx_Oracle 在 64 位 Itanium 版本的 Windows 上工作的人的意见 - 我不是第一个尝试这个的人。

最佳答案

我最终选择了选项 #2:我下载了 32 位 Oracle Instant Client,然后使用即时客户端为 32 位 Python 编译了 cx_Oracle。所以涉及的所有内容都是 32 位的,我只是没有使用任何 IA64 位可执行文件,这工作得很好。

如果我有 IA64 编译器,我会尝试选项 #3,但事实证明 Visual Studio Pro 不支持 IA64 平台,我们需要花很多钱才能升级到更高的平台比专业版。

关于python - 如何让 cx_Oracle 在 64 位 Itanium Windows 上运行?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/2024016/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com