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

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

iter onf brush enc extern base 分別是 port clas

在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

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