2016-08-05 130 views
3

我已经搜索了一些日子,尝试了几个建议,但没有任何帮助。目前我只想创建一个连接到Oracle数据库的小Go代码片段。虽然一切工作通过使用正常的go build并调用生成的动态链接的应用程序,但当我尝试运行静态编译器时,卡住了。我已经静态构建了其他项目(即使使用CGO)也没有问题,但是这里gcc没有找到oracle库。也许有人有提示?构建过程中试图在Linux/Ubuntu上使用Oracle库构建静态CGO可执行文件

错误:

host link: "gcc" "-m64" "-gdwarf-2" "-o" "/tmp/go-build319417544/command-line-arguments/_obj/exe/a.out" "-static" "/tmp/go-link-116023228/000000.o" "/tmp/go-link-116023228/000001.o" "/tmp/go-link-116023228/000002.o" "/tmp/go-link-116023228/go.o" "-g" "-O2" "-g" "-O2" "-lpthread" "-g" "-O2" "-L/usr/lib/oracle/12.1/client64/lib" "-lclntsh" "-static" 
/home/hannes/.gvm/gos/go1.5/pkg/tool/linux_amd64/link: running gcc failed: exit status 1 
/usr/bin/ld: cannot find -lclntsh 
collect2: error: ld returned 1 exit status 

生成命令

CGO_ENABLED=1 go build -work -x -ldflags " -v -linkmode external -extldflags -static" ${MAIN_SRC} 

施药代码:

package main 
/* 
// #cgo CFLAGS: -I/usr/lib/oracle/12.1/client64/include 
// #cgo LDFLAGS: -L/usr/lib/oracle/12.1/client64/lib -lclntsh 
*/ 
import "C" 
import (
    "fmt" 
    "database/sql" 
    _ "github.com/mattn/go-oci8" 
    "time" 
) 

func main(){ 


    db, err := sql.Open("oci8", "...") 
    ... 
} 

我与

dconfig -p | grep cln 
libkadm5clnt_mit.so.9 (libc6,x86-64) => /usr/lib/x86_64-linux-gnu/libkadm5clnt_mit.so.9 
libclntshcore.so.12.1 (libc6,x86-64) => /usr/lib/oracle/12.1/client64/lib/libclntshcore.so.12.1 
libclntshcore.so (libc6,x86-64) => /usr/lib/oracle/12.1/client64/lib/libclntshcore.so 
libclntsh.so.12.1 (libc6,x86-64) => /usr/lib/oracle/12.1/client64/lib/libclntsh.so.12.1 
libclntsh.so (libc6,x86-64) => /usr/lib/oracle/12.1/client64/lib/libclntsh.so 
检查

动态建立可执行文件(只是“去打造oracle_test.go)有它需要的一切:

ldd oracle_test 
linux-vdso.so.1 => (0x00007ffeac867000) 
libpthread.so.0 => /lib/x86_64-linux-gnu/libpthread.so.0 (0x00007f083ef82000) 
libclntsh.so.12.1 => /usr/lib/oracle/12.1/client64/lib/libclntsh.so.12.1 (0x00007f083bfc5000) 
libc.so.6 => /lib/x86_64-linux-gnu/libc.so.6 (0x00007f083bbfa000) 
/lib64/ld-linux-x86-64.so.2 (0x00005615b32e8000) 
libmql1.so => /usr/lib/oracle/12.1/client64/lib/libmql1.so (0x00007f083b984000) 
libipc1.so => /usr/lib/oracle/12.1/client64/lib/libipc1.so (0x00007f083b606000) 
libnnz12.so => /usr/lib/oracle/12.1/client64/lib/libnnz12.so (0x00007f083aefb000) 
libons.so => /usr/lib/oracle/12.1/client64/lib/libons.so (0x00007f083acb6000) 
libdl.so.2 => /lib/x86_64-linux-gnu/libdl.so.2 (0x00007f083aab2000) 
libm.so.6 => /lib/x86_64-linux-gnu/libm.so.6 (0x00007f083a7a9000) 
libnsl.so.1 => /lib/x86_64-linux-gnu/libnsl.so.1 (0x00007f083a58f000) 
librt.so.1 => /lib/x86_64-linux-gnu/librt.so.1 (0x00007f083a387000) 
libaio.so.1 => /lib/x86_64-linux-gnu/libaio.so.1 (0x00007f083a184000) 
libclntshcore.so.12.1 => /usr/lib/oracle/12.1/client64/lib/libclntshcore.so.12.1 (0x00007f0839c12000) 

我也试图把/出口CGO_LDFLAGS和/ ORD LD_LIBRARY_PATH环境变量,它并没有帮助。

pkg配置说明以及

pkg-config --libs oci8 
-L/usr/lib/oracle/12.1/client64/lib -lclntsh 

寻找静态库后,我已经安装了该库的完整的Oracle数据库包,现在我有lib文件夹一些文件: ls /usr/lib/oracle/12.1/client64/lib/lib*.a
-rw-r--r-- 1 1424782 /usr/lib/oracle/12.1/client64/lib/libagent12.a -rw-r--r-- 1 1962088 /usr/lib/oracle/12.1/client64/lib/libasmclnt12.a -rw-r--r-- 1 2187864 /usr/lib/oracle/12.1/client64/lib/libasmclntsh12.a -rw-r--r-- 1 11386 /usr/lib/oracle/12.1/client64/lib/libasmperl12.a -rw-r--r-- 1 28454 /usr/lib/oracle/12.1/client64/lib/libavstub12.a -rw-r--r-- 1 7408322 /usr/lib/oracle/12.1/client64/lib/libcell12.a -rw-r--r-- 1 11246008 /usr/lib/oracle/12.1/client64/lib/libclient12.a -rw-r--r-- 1 0 /usr/lib/oracle/12.1/client64/lib/libclntst12.a -rw-r--r-- 1 1749282 /usr/lib/oracle/12.1/client64/lib/libclsr12.a -rw-r--r-- 1 10087032 /usr/lib/oracle/12.1/client64/lib/libcommon12.a -rw-r--r-- 1 5803698 /usr/lib/oracle/12.1/client64/lib/libcore12.a -rw-r--r-- 1 6051402 /usr/lib/oracle/12.1/client64/lib/libctx12.a -rw-r--r-- 1 1201840 /usr/lib/oracle/12.1/client64/lib/libctxc12.a -rw-r--r-- 1 56964 /usr/lib/oracle/12.1/client64/lib/libctxs12.a ...snipped...

由于看到一个文件具有零大小,所以我必须运行$ ORACLE_HOME/bin/genclntst来生成libclntst12.a。

+0

如果'/ usr/lib/oracle/12没有显示。1/client64/lib /'包含你需要的所有东西的静态库(或者如果系统具有静态版本的依赖关系,但更可能) – JimB

+0

嗨,我不得不承认,编译时我没有太多的知识静态程序。所以,这里是我的目录: 'LS /usr/lib/oracle/12.1/client64/lib/ glogin.sql中 libclntsh.so libclntsh.so.12.1 libclntshcore.so libclntshcore.so.12.1 libipc1。所以 libmql1.so libnnz12.so libocci.so libocci.so.12.1 libociei.so libocijdbc12.so libons.so liboramysql12.so libsqlplus.so libsqlplusic.so ojdbc6.jar ojdbc7。罐子 ottclasses.zip xstreams.jar ' – hanneslehmann

回答

1
  • 使用$ ORACLE_HOME/bin中/重链接工具来生成一个名为libclntst.ast代表静态库的库。 Oracle客户端通常不附带此文件。
  • 尝试将您的应用程序与此库链接。你很可能会发现很多符号缺失。
  • 使用nm工具来查找这些缺失符号的来源。
  • 在11gR2中的情况下,此命令为我工作:

    /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 
    

静态链接要求,您手动解决所有的依赖关系。 在本例中,libclntst11.a依赖于来自libippdcmerged.a和libippsmerged.a的符号。

在旧的Oracle版本上,整个数据库都是使用Intel的ICC编译器构建和链接的。因此,当静态链接Oracle的客户端库时,您还必须从ICC运行时添加一些静态库。

+0

嗨,谢谢你的快速回答。我的安装中没有relink工具(我没有oracle完全安装),我下载了一些即时客户端软件包,并通过外星人将它们安装在ubuntu上(按照以下说明操作:[https:// help .ubuntu.com/community/Oracle%20Instant%20Client])。稍后将检查,如果relink在我还没有解压缩/安装的其他软件包内。 – hanneslehmann

+0

嗨,所以我发现(见上面的评论)我错过了“.a”静态库。我的文件夹只包含共享文件。现在我正在追逐$ ORACLE_HOME/bin/relink,因为它不能通过我从Ubuntu社区跟踪的安装过程获得。我希望该工具将生成“.a”文件 – hanneslehmann

+0

嗨,同时我已经安装了oracle安装并找到了relink工具。在工具的日志中,我发现了一些关于链接器的错误消息(再次),所以我必须通过它们来修复它们,直到我得到静态库....我猜... – hanneslehmann

相关问题