我在 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 DLLs 有一个无效的文件格式。
在这一点上,我有很多选择,我不知道该把我的努力放在哪里:
我可以从http://sourceforge.net/projects/mingw-w64/下载 64 位 MinGW并尝试使用它,但它似乎只能作为源代码使用,所以我必须编译编译器,可能使用视觉工作室 2005。
我可以尝试使用 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,但这似乎可行。
我可以尝试使用 Visual Studio 2005 从源代码编译 Python 本身,这样我就可以使用 Visual Studio 2005 构建 cx_Oracle 而不必担心二进制兼容性问题。我已经在 Linux 上多次从源代码编译 Python 并且从未遇到任何问题,所以我想相信它在 Windows 上同样简单。
我可以尝试弄清楚如何使 Visual Studio 2005 链接到正确的 DLL,从而在不需要 Visual Studio 2003 的情况下以这种方式生成兼容的二进制文件。直观地说,Visual Studio 似乎应该能够生成与旧版本本身兼容的二进制文件,但我几乎所有的编译器经验都是使用 gcc,所以我真的不知道。
我真的不知道该把我的努力指向哪里。有人对下一步去哪里有任何建议吗?如果有帮助,我可以复制/粘贴我收到的一些特定错误消息。
我特别想听听任何曾经让 cx_Oracle 在 64 位 Itanium 版本的 Windows 上工作的人的消息——我不能成为第一个尝试这个的人。