问题描述
Linux下python3.7连接oracle报错:

import cx_Oracle
conn = cx_Oracle.connect("user/passwd@ip:port/dbname")

Traceback (most recent call last):
  File "<stdin>", line 1, in <module>
cx_Oracle.DatabaseError: DPI-1047: Cannot locate a 64-bit Oracle Client library: "libclntsh.so: cannot open shared object file: No such file or directory". See https://cx-oracle.readthedocs.io/en/latest/user_guide/installation.html for help

在这里插入图片描述
解决方案
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、连接测试,连接成功
在这里插入图片描述

Logo

为开发者提供学习成长、分享交流、生态实践、资源工具等服务,帮助开发者快速成长。

更多推荐