码迷,mamicode.com
首页 > 数据库 > 详细

Deeping中使用python连接Oralce报错:Cannot locate a 64-bit Oracle Client library: "./instantclient_21_1/libclntsh.so: file too short"

时间:2021-06-28 19:23:30      阅读:0      评论:0      收藏:0      [点我收藏+]

标签:inux   内网   存储   init   执行   oracle   程序   cursor   ati   

背景

最近工作中经常会有测试、项目经理让我查一下生产问题,每次都要去数据库查半天,数据库是部署在客户内网的一个Oracle数据库,
个人对于Oracle数据库的存储过程不太熟悉,于是想着写个Python脚本方便以后排查问题。网上搜到目前Python连接Oracle数据库
最好用的库是cx_Oracle,结果第一句代码报错就搞了半天_-_

本文所述系统及工具版本

操作系统:Deepin GNU/Linux 20.2
python版本:3.8.5
oralce instantclien版本:instantclient_21_1

代码及错误堆栈

代码

import cx_Oracle
import os


def connect_oracle():
    # 加载oracle客户端
    cx_Oracle.init_oracle_client(lib_dir="./instantclient_21_1")

    # 连接数据库
    db = cx_Oracle.connect(‘test‘, ‘testpassword‘, ‘127.0.0.1:1521/testdb‘)
    cur = db.cursor()
    result = cur.execute("SELECT * FROM test_table tt WHERE tt.number = 10")
    for i in result:
        print(i)


if __name__ == "__main__":
    connect_oracle()

错误堆栈

技术图片

问题解决过程

1.刚开始以为是文件夹或文件的权限问题,毕竟linux系统中权限问题涉及的是很多的,于是给instantclient_21_1增加读写权限,没用;
2.后来以为是绝对路径的问题,于是将instantclient_21_1移到python程序的目录下,使用相对路径,没用;
3.网上搜索,尝试了几种方案,设置了Oracle的一些环境变量之类的,没用;
4.老老实实跟着错误提示里面的链接去看cx_Oracle的安装文档:
技术图片
cx_Oracle安装文档
直接看linux的部分:https://cx-oracle.readthedocs.io/en/latest/user_guide/installation.html#installing-cx-oracle-on-linux
安装第四步:
技术图片
如果机器上没有Oracle软件将会受到影响,要求我们持久化instantclient的路径到运行连接里面,执行下面的代码即可:

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

为了确保和文档上完全一致,我最后也把instantclient_21_1这个文件夹已到了/opt/oracle目录下面,这个方法成功。。。该早点看文档的,
就是每次看英文文档看的想睡觉就下意识的拒绝。

Deeping中使用python连接Oralce报错:Cannot locate a 64-bit Oracle Client library: "./instantclient_21_1/libclntsh.so: file too short"

标签:inux   内网   存储   init   执行   oracle   程序   cursor   ati   

原文地址:https://www.cnblogs.com/alinainai/p/14939607.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!