Python 程序无法找到 Oracle 的 64 位客户端库 (libclntsh.so)

数据库错误: DPI-1047: Cannot locate a 64-bit Oracle Client library: "libclntsh.so: cannot open shared object file: No such file or directory". See https://oracle.github.io/odpi/doc/installation.html#linux for help

这个错误表明 Python 程序无法找到 Oracle 的 64 位客户端库 (libclntsh.so)。以下是完整的解决方案:


完整解决方案(Linux 环境)

1. 安装 Oracle Instant Client(推荐方式)

(1) 下载 Oracle Instant Client Basic 包

从 Oracle 官网下载 19c 或 21c 版本的 Basic 包:

bash

# 进入下载目录(如 /opt/oracle)
sudo mkdir -p /opt/oracle
cd /opt/oracle# 下载 Basic 包(示例为 19.19 版本)
wget https://download.oracle.com/otn_software/linux/instantclient/199000/instantclient-basic-linux.x64-19.9.0.0.0dbru.zip# 解压
sudo unzip instantclient-basic-linux.x64-19.9.0.0.0dbru.zip

如果 wget 报错,可手动从 Oracle 官网 下载并上传到服务器。

(2) 设置环境变量

bash

# 临时生效(当前会话)
export LD_LIBRARY_PATH=/opt/oracle/instantclient_19_9# 永久生效(写入 ~/.bashrc 或 /etc/profile)
echo 'export LD_LIBRARY_PATH=/opt/oracle/instantclient_19_9' >> ~/.bashrc
source ~/.bashrc
(3) 创建符号链接(关键步骤!)

bash

sudo ln -s /opt/oracle/instantclient_19_9/libclntsh.so.19.1 /usr/lib/libclntsh.so

sudo yum install libnsl


2. 验证是否生效

bash

# 检查库文件是否存在
ls -l /opt/oracle/instantclient_19_9/libclntsh.so*# 检查环境变量
echo $LD_LIBRARY_PATH# 测试 Python 是否能导入 cx_Oracle
python3 -c "import cx_Oracle; print('Success')"

如果没有报错,说明配置成功!


3. 在你的 Python 代码中强制指定 Oracle 客户端路径

如果仍然报错,可以在代码中显式指定 Oracle 客户端路径:

python

import cx_Oracle# 手动指定 Oracle 客户端路径
cx_Oracle.init_oracle_client(lib_dir="/opt/oracle/instantclient_19_9")# 然后正常连接数据库
conn = cx_Oracle.connect("DB_MON/db_mon@rpt2.fastfish.com.cn:1521/orcl")

4. 其他可能的问题

(1) 32 位 vs 64 位不匹配
  • 确保 Python 和 Oracle Instant Client 都是 64 位

    bash

    # 检查 Python 位数
    python3 -c "import sys; print(sys.maxsize > 2**32)"
    • 输出 True 表示 64 位 Python。

  • 检查 Oracle Instant Client 位数:

    bash

    file /opt/oracle/instantclient_19_9/libclntsh.so
    • 应显示 ELF 64-bit

(2) 缺少 libaio 依赖

bash

# CentOS/RHEL
sudo yum install libaio# Ubuntu/Debian
sudo apt-get install libaio1
(3) 文件权限问题

确保当前用户有权访问 Oracle Instant Client:

bash

sudo chmod -R +r /opt/oracle/instantclient_19_9

5. 最终代码示例

python

import cx_Oracle
import os# 设置 Oracle 客户端路径(可选)
os.environ["LD_LIBRARY_PATH"] = "/opt/oracle/instantclient_19_9"# 显式初始化 Oracle 客户端
cx_Oracle.init_oracle_client(lib_dir="/opt/oracle/instantclient_19_9")# 连接数据库
try:conn = cx_Oracle.connect("DB_MON/db_mon@rpt2.fastfish.com.cn:1521/orcl")print("连接成功!")conn.close()
except Exception as e:print("连接失败:", e)

总结

问题解决方案
DPI-1047 错误安装 Oracle Instant Client 并设置 LD_LIBRARY_PATH
libclntsh.so 找不到检查路径并创建符号链接
32/64 位不匹配确保 Python 和 Oracle 客户端都是 64 位
缺少 libaio安装 libaioyum install libaio 或 apt install libaio1
权限问题确保 /opt/oracle 可读

如果仍然报错,请检查:

  1. 是否下载了正确版本的 Instant Client?

  2. LD_LIBRARY_PATH 是否生效?

  3. 是否执行了 source ~/.bashrc

希望这能彻底解决问题! 🚀

方法1:直接通过命令修改(临时生效)

bash

export LD_LIBRARY_PATH=/opt/oracle/instantclient_19_9
方法2:永久修改(编辑.bashrc文件)
  1. 打开.bashrc文件:

bash

nano ~/.bashrc
  1. 找到设置LD_LIBRARY_PATH的行(可能是这样的):

bash

export LD_LIBRARY_PATH=/opt/oracle/instantclient_19_9:/opt/oracle/instantclient_19_9:
  1. 修改为(删除重复路径和结尾冒号):

bash

export LD_LIBRARY_PATH=/opt/oracle/instantclient_19_9
  1. 保存退出nano:

  • 按 Ctrl+O 保存

  • 按 Enter 确认

  • 按 Ctrl+X 退出

  1. 使修改生效:

bash

source ~/.bashrc

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如若转载,请注明出处:http://www.pswp.cn/web/89847.shtml
繁体地址,请注明出处:http://hk.pswp.cn/web/89847.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Kubernetes常用命令总结

文章目录Kubernetes常用命令总结1. 集群管理命令kubectl cluster-infokubectl get nodeskubectl describe node <node-name>kubectl top nodes2. Pod相关命令kubectl get podskubectl get pods -o widekubectl describe pod <pod-name>kubectl logs <pod-name&g…

roboflow使用教程

如何利用roboflow标注自己的训练集、调用开源数据集 官网&#xff1a;Roboflow: Computer vision tools for developers and enterprises&#xff08;国内代理进不去&#xff09; 先注册登陆进去 训练自己的数据集 点击“New Project”,名字按照自己的需求来 我不想写了&am…

IDEA中使用Tomcat两种方式

Catalogue1 集成本地Tomcat2 Tomcat Maven插件&#xff08;推荐&#xff09;1 集成本地Tomcat 将本地Tomcat集成到Idea中&#xff0c;然后进行项目部署即可 点击编辑配置 点击加号 添加local的Tomcat 配置Application Server 可以修改一下Name 至此&#xff0c;配置完成 …

服务器上的文件复制到本地 Windows 系统

在 Windows 上通过 SSH 连接到 Linux 服务器后&#xff0c;如果需要将服务器上的文件复制到本地 Windows 系统&#xff0c;可以使用以下几种方法&#xff1a;方法 1&#xff1a;使用 scp&#xff08;Secure Copy&#xff09;命令 scp&#xff08;基于 SSH 的安全复制&#xff0…

大语言模型置信度增强实战指南

LLM怎么简单增强置信度 在大语言模型(LLM)的应用中,“置信度增强”核心目标是提升模型输出的可靠性(减少错误/幻觉) 并让模型更清晰地表达自身的不确定性(避免“一本正经地胡说”)。常用方式可分为“输出优化”“知识补充”“校准调整”三大类, 一、基于“推理过程优…

NLP:人名分类器案例分享

本文目录&#xff1a;一、案例介绍&#xff08;一&#xff09;关于人名分类&#xff08;二&#xff09;人名分类数据预览二、案例步骤&#xff08;一&#xff09;导入工具包&#xff08;二&#xff09;数据预处理1. 获取常用的字符数量2. 国家名种类数和个数3.读数据到内存4.构…

3分钟实战!用DeepSeek+墨刀AI生成智能对话APP原型图

如今&#xff0c;AI生成原型图已经逐渐成为产品经理的一项常用辅助技能&#xff0c;不仅能加快设计进程&#xff0c;还能显著提升前期沟通效率。最近我尝试将大语言模型工具与AI原型工具结合测试&#xff0c;目标是看看是否能生成更高质量的原型页面。直到我使用DeepSeek墨刀AI…

CentOS网络配置与LAMP环境搭建指南

一、CentOS配置网络1、查看网卡名称ifconfig2、找到网卡对应配置文件网卡存放路径 &#xff1a;/etc/sysconfig/network-scriptscd /etc/sysconfig/network-scripts3、修改网卡对应配置文件使用 vi/vim 打开文件&#xff0c;查看以下内容vim ifcfg-ens33将ONBOOTno 改为 ONBOOT…

TinyMCE 富文本编辑器在 vue2 中的使用 @tinymce/tinymce-vue

TinyMCE是一款功能强大、高度可定制的富文本编辑器。官方文档 TinyMCE DOCS tinymce-vue包的版本4及更高版本支持Vue.js 3。但不支持Vue.js 2.x。对于Vue.js 2。X应用程序&#xff0c;使用tinymce-vue版本3。 安装TinyMCE和Vue集成包 npm install tinymce/tinymce-vue3 tiny…

LP-MSPM0G3507学习--04GPIO控制

关键函数&#xff1a; DL_GPIO_readPins(GPIO_Regs* gpio, uint32_t pins):同时读一组端口DL_GPIO_writePins(GPIO_Regs* gpio, uint32_t pins)&#xff1a;同时写一组端口DL_GPIO_setPins(GPIO_Regs* gpio, uint32_t pins)&#xff1a;对指定某组端口的某管脚置高DL_GPIO_cle…

LVS(Linux virtual server)-实现四层负载均衡

一、简介LVS:Linux Virtual Server&#xff0c;负载调度器&#xff0c;内核集成&#xff0c;章文嵩&#xff0c;阿里的四层SLB(Server LoadBalance)是基 于LVSkeepalived实现LVS 官网: http://www.linuxvirtualserver.org/二、LVS运行原理2.1LVS 的集群结构2.2lvs相关概念RS&am…

Kubernetes CNI网络插件性能瓶颈排查与优化实践

Kubernetes CNI网络插件性能瓶颈排查与优化实践 CNI&#xff08;Container Network Interface&#xff09;是 Kubernetes 网络层的核心组件&#xff0c;不同 CNI 插件实现了容器间网络通信、多租户隔离、流量限速等功能。然而在大规模集群或高并发业务场景下&#xff0c;CNI 插…

20250720-6-Kubernetes 调度-nodeName字段,DaemonS_笔记

一、污点与容忍&#xfeff;1. 给节点添加污点&#xfeff;1&#xff09;命令格式基本语法&#xff1a;kubectl taint node [node] keyvalue:[effect]示例&#xff1a;kubectl taint node k8s-node1 gpuyes:NoSchedule操作说明&#xff1a;与打标签命令类似&#xff0c;将"…

微软开源项目 Detours 详细介绍与使用实例分享

目录 1、Detours概述 2、Detours功能特性 3、Detours工作原理 4、Detours应用场景 5、Detours兼容性 6、Detours具体使用方法 7、Detours使用实例 - 使用Detours拦截系统库中的UnhandledExceptionFilter接口,实现对程序异常的拦截 C++软件异常排查从入门到精通系列教程…

研发知识系统选型实战:从 Notion 到 Gitee Wiki 的迭代经验

关键词&#xff1a;知识管理、版本控制、协作编辑、国产平台、研发效能 在日常研发管理中&#xff0c;知识管理平台往往被视为“非核心工具”&#xff0c;但它的好坏直接影响着团队交接效率、文档可用性以及协作深度。过去几年&#xff0c;我们团队先后使用过 Notion、Confluen…

从一开始的网络攻防(三):sqlmap快速上手

一、确定目标 使用sqlmap的第一步是确定探测的目标&#xff0c;一般有四种&#xff1a; 数据库URL文件Google批量扫 环境 Target IP: 192.168.8.133 Port: 13306(Mysql)、8088(sqli_labs) mysql&#xff1a; docker pull的最新mysql sqlmap github&#xff1a;https://g…

《Anaconda 精简路径治理》系列 · 番外篇Conda 虚拟环境路径结构方案全解——六种路径布局对比、优劣与治理建议

Python 多版本环境治理理念驱动的系统架构设计&#xff1a;三维治理、四级隔离、五项自治 原则-CSDN博客 Anaconda 路径精简后暴露 python 及工具到环境变量的配置记录-CSDN博客 【终极实战】Conda/Poetry/Virtualenv/Pipenv/Hatch 多工具协同 AnacondaPyCharm&#xff1a;构建…

容器基础知识3-kubectl、kubeadm 和 kubelet,kube-proxy

kubectl、kubeadm 和 kubelet&#xff0c;kube-proxy的概念和关系一、kubeadm&#xff1a;K8s 集群的 “搭建工程师”核心定位如果把 K8s 集群比作一栋大楼&#xff0c;kubeadm 就是负责 “打地基、搭框架” 的工程师&#xff0c;专门用来快速搭建 K8s 集群的工具。具体工作内容…

langchain调用本地ollama语言模型和嵌入模型

参考&#xff1a;ollama兼容OpenAIEmbeddings的解决思路 解决代码&#xff1a; 访问embedding模型代码 # 测试以下两个引用都可以 from langchain_openai import OpenAIEmbeddings #from langchain_community.embeddings import OpenAIEmbeddings from typing import List,…

gitlab私有化部署

以下是整理好的Markdown格式文档&#xff0c;详细描述了从下载镜像、启动镜像、修改external_url以及设置或重置root密码的步骤。 GitLab 安装与配置指南 本文档将指导您完成GitLab的安装和基本配置过程&#xff0c;包括下载镜像、启动容器、修改外部访问URL(external_url)及设…