Linux下使用Python连接Oracle 报cx_Oracle.DatabaseError: DPI-1047: 64-bit Oracle Client library cannot be lo

在Linux上使用python运行数据库脚本的时候报:cx_Oracle.DatabaseError: DPI-1047: 64-bit Oracle Client library cannot be loaded解决方法

这个导致这个问题的原因是本机的Python2.7是64位的,而数据库用了32位的instantclient-basic,所以要把instantclient-basic的版本更新为64位的

以下是按照官网文档操作的,自测没有问题.

下载instantclient-basic的RPM包或者ZIP包,64-bit or 32-bit,这里下载64位。

以下分别是RPM包和ZIP包的安装方法,两者皆可

ZIP安装方法

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

# mkdir -p /opt/oracle
# cd /opt/oracle
# unzip instantclient-basic-linux.x64-12.2.0.1.0.zip

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

# sudo yum install libaio

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

# sudo sh -c "echo /opt/oracle/instantclient_12_2 > /etc/ld.so.conf.d/oracle-instantclient.conf"
# sudo ldconfig

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

# export LD_LIBRARY_PATH=/usr/lib/oracle/12.2/client64/lib:$LD_LIBRARY_PATH

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

# mkdir -p /opt/oracle/instantclient_12_2/network/admin

RPM安装方法

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

# sudo yum install oracle-instantclient12.2-basic-12.2.0.1.0-1.x86_64.rpm

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

# sudo sh -c "echo /usr/lib/oracle/12.2/client64/lib > /etc/ld.so.conf.d/oracle-instantclient.conf"
# sudo ldconfig

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

# export LD_LIBRARY_PATH=/usr/lib/oracle/12.2/client64/lib:$LD_LIBRARY_PATH

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

# sudo mkdir -p /usr/lib/oracle/12.2/client64/lib/network/admin

解决方案

1、根据服务器信息下载相应版本的 Oracle 客户端 instantclient,我这里下载的是64位的
下载地址:

https://www.oracle.com/database/technologies/instant-client/linux-x86-64-downloads.html

或者:

下载: instantclient-basiclite-linuxx64.zip
链接:https://pan.baidu.com/s/1J98jlre2s1A0X9KxjcQQVQ
提取码:5tpg

2、把下载的zip包上传到linux并解压,这里解压到 /opt/oracle/ 下了
在这里插入图片描述
3、vim /etc/ld.so.conf
写入:/opt/oracle/instantclient_21_6
在这里插入图片描述

4、执行命令

ldconfig

5、执行命令

ldd /opt/oracle/instantclient_21_6/libclntsh.so

若出现以下红框情况,则需要进一步操作,若无则不需要
在这里插入图片描述
6、 安装libaio

1)在线安装:yum install libaio
2)离线安装:下载 libaio.so.1.0.0 和 libaio.so.1.0.1
链接:https://pan.baidu.com/s/1J98jlre2s1A0X9KxjcQQVQ
提取码:5tpg

7、把 libaio.so.1.0.0 和 libaio.so.1.0.1 上传到 /opt/oracle/instantclient_21_6/目录下
8、执行命令:

ln -s /opt/oracle/instantclient_21_6/libaio.so.1.0.1 /opt/oracle/instantclient_21_6/libaio.so.1

9、再次执行 ldd /opt/oracle/instantclient_21_6/libclntsh.so
在这里插入图片描述
10、连接测试,连接成功
在这里插入图片描述

  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值