sql >> Databasteknik >  >> RDS >> Oracle

Försöker bygga statisk CGO-körbar med oracle-bibliotek på Linux/Ubuntu

  • Använd verktyget $ORACLE_HOME/bin/relink för att skapa biblioteket med namnet libclntst.a Den st står för static library. Oracle-klienten levereras vanligtvis inte med den här filen.
  • Försök att länka din app till det här biblioteket. Du kommer med största sannolikhet att hitta många symboler som saknas.
  • Använd verktyget nm för att hitta källan till de saknade symbolerna.
  • I fallet med 11gR2 fungerade detta kommando för mig:

    /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
    

Statisk länkning kräver att du löser alla beroenden manuellt. I det här exemplet beror libclntst11.a på symboler från libippdcmerged.a och libippsmerged.a.

På äldre Oracle-version byggdes och länkades hela databasen med Intels ICC-kompilator. Så när du länkade Oracles klient lib statiskt var du också tvungen att lägga till några statiska libs från ICC:s körtid.




  1. Oracle + dbunit får AmbiguousTableNameException

  2. Skapa ett databaspostkonto (SSMS)

  3. MySQL - Välj från en lista med nummer de utan motsvarighet i id-fältet i en tabell

  4. Returnera Tidsstämpel Med Förberedd Utlåtande