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


在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


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM