cx_Oracle.DatabaseError: DPI-1047: 64-bit Oracle Client library cannot be loaded 解决方法

Linux下使用Python连接Oracle 报cx_Oracle.DatabaseError: DPI-1047: 64-bit Oracle Client library cannot be loaded解决方法

  • 这个导致这个问题的原因是本机的Python2.7是64位的
  • 而数据库用了32位的instantclient-basic
  • 所以要把instantclient-basic的版本更新为64位的
  • 以下是按照官网文档操作的,自测没有问题,这里下载64位。
    • 下载instantclient-basic的RPM包或者ZIP包,
    • 64-bit :https://www.oracle.com/technetwork/topics/linuxx86-64soft-092277.html
    • 32-bit:https://www.oracle.com/technetwork/topics/linuxsoft-082809.html
  • 可以使用RPM包和ZIP包的安装方法,两者皆可

ZIP安装方法

1.解压ZIP包并放到新建的目录中

[root@bigdata01 ~]# mkdir -p /opt/oracle
[root@bigdata01 ~]# cd /opt/oracle
[root@bigdata01 ~]# unzip instantclient-basic-linux.x64-18.3.0.0.0dbru.zip

2.使用root用户安装 libaio 包(主:在一些发行版中这个包称为libaio1)

[root@bigdata01 ~]# yum install -y libaio

3.如果服务器上没有其他的Oracle软件会受到影像,那么可以永久将客户端添加到运行时链接路径中

[root@bigdata01 ~]# sh -c "echo /app/oracle/instantclient_18_3 > /etc/ld.so.conf.d/oracle-instantclient.conf"
[root@bigdata01 ~]# ldconfig

4.或者将环境变量LD_LIBRARY_PATH设置为instantclient版本适当的目录

[root@bigdata01 ~]# export LD_LIBRARY_PATH=/usr/lib/oracle/18.3/client64/lib:$LD_LIBRARY_PATH

5.创建及时客户端的应用程序的Oracle配置目录

[root@bigdata01 ~]# mkdir -p /app/oracle/instantclient_18_3/network/admin

 

RPM安装方法

1.使用root用户安装下载的RPM包,yum安装会自动安装所需要的依赖包,比如libaio

[root@bigdata01 ~]# yum install -y libaio
[root@bigdata01 ~]# yum install oracle-instantclient12.2-basic-12.2.0.1.0-1.x86_64.rpm

  

2.如果服务器上没有其他的Oracle软件会受到影像,那么可以永久将客户端添加到运行时链接路径中

[root@bigdata01 ~]# sh -c "echo /app/oracle/instantclient_18_3 > /etc/ld.so.conf.d/oracle-instantclient.conf"
[root@bigdata01 ~]# ldconfig

3.或者将环境变量LD_LIBRARY_PATH设置为instantclient版本适当的目录

[root@bigdata01 ~]# export LD_LIBRARY_PATH=/usr/lib/oracle/18.3/client64/lib:$LD_LIBRARY_PATH

  

4.创建及时客户端的应用程序的Oracle配置目录

[root@bigdata01 ~]# mkdir -p /app/oracle/instantclient_18_3/network/admin

转载于:https://www.cnblogs.com/liangjingfu/p/9935222.html

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值