sql >> Databáze >  >> RDS >> Oracle

Pokus o vytvoření statického spustitelného souboru CGO s knihovnami Oracle na Linuxu/Ubuntu

  • Pomocí nástroje $ORACLE_HOME/bin/relink vygenerujte knihovnu s názvem libclntst.a st znamená statickou knihovnu. Klient Oracle není obvykle dodáván s tímto souborem.
  • Zkuste propojit aplikaci s touto knihovnou. S největší pravděpodobností zjistíte, že mnoho symbolů chybí.
  • K nalezení zdroje těchto chybějících symbolů použijte nástroj nm.
  • V případě 11gR2 mi tento příkaz fungoval:

    /usr/bin/c++ -Wall -ggdb3 -fPIC \
     CMakeFiles/opassgen.dir/opassgen.cpp.o \
     CMakeFiles/opassgen.dir/dbutils.cpp.o \
     CMakeFiles/opassgen.dir/common.cpp.o  \
     CMakeFiles/opassgen.dir/crypto.cpp.o  \
     n.o  -o opassgen                      \
     -rdynamic -static-libgcc -L. -Wl,-Bstatic -lstdc++ -Wl,-Bdynamic \
     /home/oracle/ivan/openssl-1.0.1t/libcrypto.a  \
     /oracle/u01/db/11.2.0.4/lib/libclntst11.a     \
     /oracle/u01/db/11.2.0.4/lib/libippdcmerged.a  \
     /oracle/u01/db/11.2.0.4/lib/libippsmerged.a   \
     -Wl,--whole-archive libtrotl.a -Wl,--no-whole-archive \
     -lpthread -ldl
    

Statické propojení vyžaduje, abyste vyřešili všechny závislosti ručně. V tomto příkladu libclntst11.a závisí na symbolech z libippdcmerged.a a libippsmerged.a.

Na starší verzi Oracle byla celá databáze sestavena a propojena pomocí ICC kompilátoru Intel. Takže když jste staticky propojovali klientskou knihovnu Oracle, museli jste také přidat některé statické knihovny z runtime ICC.




  1. Způsoby obnovení dat ze souboru protokolu transakcí serveru SQL Server

  2. Počet SQL ze spojené tabulky

  3. Klauzule SQL mezi se sloupci řetězců

  4. Lehká instalace WordPress:Jak nainstalovat WordPress s SQLite