【问题标题】:How do I get cx_Oracle to work on 64-bit Itanium Windows?如何让 cx_Oracle 在 64 位 Itanium Windows 上工作?
【发布时间】:2011-01-02 16:48:09
【问题描述】:

我在 64 位 Itanium 服务器上运行 Windows Server 2003,该服务器也运行 64 位 Oracle 10.2,我想为 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 上工作的人的意见 - 我不是第一个尝试这个的人。

【问题讨论】:

  • 由于 sourceforge.net 上的 mingw-w64 项目正在转移到 mingw-w64.org 我建议使用mingw-w64.org

标签: python windows 64-bit cx-oracle itanium


【解决方案1】:

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

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

【讨论】:

    【解决方案2】:

    我昨天读了这篇文章,看到没有人回答我并不感到惊讶。这是一个非常具体和复杂的问题。虽然我对您处理的许多工具没有直接经验,但我已经解决了与不同编译器和二进制文件不兼容的问题。物有所值 3. 听起来是你最好的选择。

    【讨论】:

      猜你喜欢
      • 2017-06-08
      • 2013-11-10
      • 1970-01-01
      • 2019-12-29
      • 2011-03-29
      • 2012-04-01
      • 2012-06-14
      • 2017-12-13
      • 1970-01-01
      相关资源
      最近更新 更多