设为首页收藏本站
查看: 108|回复: 0

[PHP] 安装cx_Oracle会遇到的报错以及解决方案

[复制链接]

论坛元老

Rank: 6Rank: 6

积分
34273
主题
17031
UID
1347
M币
67
贡献
17175

  • 发表于 2017-5-14 02:44:00 | 显示全部楼层 |阅读模式
    这篇文章主要介绍了python安装cx_Oracle模块常见问题与解决方法,举例分析了Python在Windows平台与Linux平台安装cx_Oracle模块常见问题、解决方法及相关注意事项,需要的朋友可以参考下
    本文实例讲述了python安装cx_Oracle模块常见问题与解决方法。分享给大家供大家参考,具体如下:
    安装或使用cx_Oracle时,需要用到Oracel的链接库,如libclntsh.so.10.1,否则会有各种各样的错误信息。
    安装Oracle Instant Client就可得到这个链接库,避免安装几百兆之巨的Oracle Client。
    软件下载地址:
    cx_Oracle的主页:cx-oracle.sourceforge.net/
    必需的Oracle链接库的下载地址:www.oracle.com/technology/software/tech/oci/instantclient/index.html
    常见的错误和解决方法:
    一.win32二进制安装
    在windows下安装cx_Oracle-5.0-10g.win32-py2.6.msi之后,导入时,报DLL加载失败的错误,如下:
    IDLE 2.6.1
    >>> import cx_Oracle Traceback (most recent call last): File "", line 1, in  import cx_Oracle ImportError: DLL load failed: 找不到指定的程序。解决方法:
    从Oracle站点下载instantclient-basic-win32-10.2.0.4.zip,解压后,将其中的oci.dll文件复制到Python安装目录的Lib/site-packages下,如 C:/Python26/Lib/site-packages
    二.linux下二进制安装
    在linux_x86_64下,安装cx_Oracle-5.0.1-10g-py24-1.x86_64.rpm时报错。
    [root@BJ-UPDATE-01 ~]# rpm -ivh cx_Oracle-5.0.1-10g-py24-1.x86_64.rpm error: Failed dependencies: libclntsh.so.10.1()(64bit) is needed by cx_Oracle-5.0.1-1.x86_64解决方法:
    参考cx-oracle.sourceforge.net/BUILD.txt
    从Oracle站点下载basic-10.2.0.4.0-linux-x86_64.zip到/opt目录并解压,会看到libclntsh.so.10.1在/opt/instantclient_10_2目录中
    设置环境变量
    vi /root/.bash_profile增加如下两行:
    export ORACLE_HOME=/opt/instantclient_10_2 export LD_LIBRARY_PATH=$LD_LIBRARY_PATH:$ORACLE_HOME运行source /root/.bash_profile使改动生效
    建立此链接库的符号链接
    cd $ORACLE_HOME ln -s libclntsh.so.x.x libclntsh.so重新安装cx_Oracle
    注意加--nodeps参数,否则还会报上述错误
    [root@BJ-UPDATE-01 ~]# rpm -ivh --nodeps cx_Oracle-5.0.1-10g-py24-1.x86_64.rpm #5.0.3版本不用加--nodeps参数三.linux下源代码安装
    设置环境变量及符号链接如上,在linux_x86_64下源代码安装,运行python setup.py build,编译时错误信息如下:
    Connection.c:1169: 警告:语句不起作用
    Connection.c:1171: 错误:'udt_Connection' 没有名为 'environment' 的成员
    Connection.c:1172: 警告:传递参数 1 (属于 'Environment_CheckForError')时在不兼容的指针类型间转换
    Connection.c:1172: 警告:传递参数 2 (属于 'Environment_CheckForError')时在不兼容的指针类型间转换
    Connection.c:1172: 错误:提供给函数 'Environment_CheckForError' 的实参太多
    Connection.c:1176: 错误:'udt_Connection' 没有名为 'sessionHandle' 的成员
    解决方法:
    5.0.3版本的未出现此错误,要注意ORACLE_HOME下要有include目录,这个目录中要有编译需要的源文件,源文件在Oracle Instant Client这个客户端中没有包含。我是从windows客户端的D:/oracle/product/10.2.0/client_1/oci/include这个目录中拷贝的。
    四.import错误
    >>> import cx_Oracle Traceback (most recent call last): File "", line 1, in ? ImportError: /usr/lib/oracle/10.2.0.4/client64//lib/libnnz10.so: cannot restore segment prot after reloc: Permission denied >>> import cx_Oracle Traceback (most recent call last): File "", line 1, in ? ImportError: /usr/lib/oracle/10.2.0.4/client64//lib/libclntsh.so.10.1: cannot restore segment prot after reloc: Permission denied >>> import cx_Oracle >>>这是因为SELinux的限制,运行如下命令取消限制:
    chcon -t texrel_shlib_t cd $ORACLE_HOME/libnnz10.so chcon -t texrel_shlib_t cd $ORACLE_HOME/libclntsh.so.10.1五、运行时错误
    Traceback (most recent call last): File "oracle_conn.py", line 9, in ? cOnnection= cx_Oracle.Connection(u"oracle/oracle123@CCIP") cx_Oracle.InterfaceError: Unable to acquire Oracle environment handle还是SELinux的限制,设置SELinux为disabled
    关掉selinux:
    运行命令: vim /etc/selinux/config
    将selinux=enforcing或permissive改成disabled
    运行命令: setenforce 0
    六. UNICODE的安装包有问题
    Traceback (most recent call last): File "./oracle_conn.py", line 22, in ? folderIds=cursor.fetchmany(10) cx_Oracle.DatabaseError: OCI-22061: Message 22061 not found; No message file for product=RDBMS, facility=OCI; arguments: [T
    回复

    使用道具 举报

    您需要登录后才可以回帖 登录 | 立即注册

    本版积分规则

    在我站开通SVIP可同时获得17个站点VIP资源 立即登录 立即注册
    快速回复 返回顶部 返回列表