/usr/lib 似乎不是默认链接位置

/usr/lib appears not to be a default link location

本文关键字:默认 链接 位置 usr lib      更新时间:2023-10-16

编辑:
经过更多的挖掘,我发现我在/usr/lib/i386-linux-gnu/libGL.so有一个 libGL.so,如果我把它移开,那么链接再次正常工作。在查看错误行一段时间后,我认为消息中 libGL.so 的完整路径是可疑的,因为它会查看多个位置以找到它,并且通常它只显示库的名称而不是一个特定的完整路径。所以现在的问题是;为什么找到另一个版本会导致搜索停止并显示令人困惑的错误消息?(我是 i386ness 使其以某种方式不兼容)。

奥里格:
由于某种原因,我在将 libGL.so 链接到我的应用程序中时遇到问题。问题似乎是 ld(或在这种情况下为 gold)在尝试查找它时没有在/usr/lib(从我能找到的所有位置来看是默认位置之一)中查找,而是在查找有点古怪的位置,例如

/

usr/bin/ld: 错误: 无法打开/usr/lib/gcc/i686-linux-gnu/4.7/../../../i386-linux-gnu/libGL.so: 否 此类文件或目录

现在/usr/lib/libGL.so 肯定存在,如果我在 makefile 中执行显式 -L/usr/lib,则所有链接都可以正确。

我想知道有谁知道这里发生了什么?

信息:
Ubuntu linux 12.10 x86
G++ 4.7
GNU 黄金链接器
中央处理器 AMD 皓形 2 x6
uname -m 输出: i686

编辑:带有 -v 参数的链接输出:

Using built-in specs.
COLLECT_GCC=g++
COLLECT_LTO_WRAPPER=/usr/lib/gcc/i686-linux-gnu/4.7/lto-wrapper
Target: i686-linux-gnu
Configured with: ../src/configure -v --with-pkgversion='Ubuntu/Linaro 4.7.2-2ubuntu1' --with-bugurl=file:///usr/share/doc/gcc-4.7/README.Bugs --enable-languages=c,c++,go,fortran,objc,obj-c++ --prefix=/usr --program-suffix=-4.7 --enable-shared --enable-linker-build-id --with-system-zlib --libexecdir=/usr/lib --without-included-gettext --enable-threads=posix --with-gxx-include-dir=/usr/include/c++/4.7 --libdir=/usr/lib --enable-nls --with-sysroot=/ --enable-clocale=gnu --enable-libstdcxx-debug --enable-libstdcxx-time=yes --enable-gnu-unique-object --enable-plugin --enable-objc-gc --enable-targets=all --disable-werror --with-arch-32=i686 --with-tune=generic --enable-checking=release --build=i686-linux-gnu --host=i686-linux-gnu --target=i686-linux-gnu
Thread model: posix
gcc version 4.7.2 (Ubuntu/Linaro 4.7.2-2ubuntu1) 
COMPILER_PATH=/usr/lib/gcc/i686-linux-gnu/4.7/:/usr/lib/gcc/i686-linux-gnu/4.7/:/usr/lib/gcc/i686-linux-gnu/:/usr/lib/gcc/i686-linux-gnu/4.7/:/usr/lib/gcc/i686-linux-gnu/
LIBRARY_PATH=/usr/lib/gcc/i686-linux-gnu/4.7/:/usr/lib/gcc/i686-linux-gnu/4.7/../../../i386-linux-gnu/:/usr/lib/gcc/i686-linux-gnu/4.7/../../../../lib/:/lib/i386-linux-gnu/:/lib/../lib/:/usr/lib/i386-linux-gnu/:/usr/lib/../lib/:/usr/lib/gcc/i686-linux-gnu/4.7/../../../:/lib/:/usr/lib/
COLLECT_GCC_OPTIONS='-o' 'application' '-v' '-L/home/user/src/tutorials/application/builds/./vendor/ogre3d/./lib' '-shared-libgcc' '-mtune=generic' '-march=i686'
 /usr/lib/gcc/i686-linux-gnu/4.7/collect2 --sysroot=/ --build-id --no-add-needed --as-needed --eh-frame-hdr -m elf_i386 --hash-style=gnu -dynamic-linker /lib/ld-linux.so.2 -z relro -o application /usr/lib/gcc/i686-linux-gnu/4.7/../../../i386-linux-gnu/crt1.o /usr/lib/gcc/i686-linux-gnu/4.7/../../../i386-linux-gnu/crti.o /usr/lib/gcc/i686-linux-gnu/4.7/crtbegin.o -L/home/user/src/tutorials/application/builds/./vendor/ogre3d/./lib -L/usr/lib/gcc/i686-linux-gnu/4.7 -L/usr/lib/gcc/i686-linux-gnu/4.7/../../../i386-linux-gnu -L/usr/lib/gcc/i686-linux-gnu/4.7/../../../../lib -L/lib/i386-linux-gnu -L/lib/../lib -L/usr/lib/i386-linux-gnu -L/usr/lib/../lib -L/usr/lib/gcc/i686-linux-gnu/4.7/../../.. /home/user/src/tutorials/application/builds/./src/most_basic_main.o /home/user/src/tutorials/application/builds/./src/QOgreWidget.o /home/user/src/tutorials/application/builds/./src/QtOgreApplication.o /home/user/src/tutorials/application/builds/./src/qt_gen/QtOgreApplication.moc.o /home/user/src/tutorials/application/builds/./src/qt_gen/QOgreWidget.moc.o -lpthread -lQtCore -lQtNetwork -lQtGui -lQtOpenGL -lRenderSystem_GLStatic -lOgreMainStatic -ldl -lfreetype -lXrandr -lGL -lGLU -lxcb -lX11 -lXext -lXpm -lXaw7 -lXt -lzzip -lfreeimage -lstdc++ -lm -lgcc_s -lgcc -lc -lgcc_s -lgcc /usr/lib/gcc/i686-linux-gnu/4.7/crtend.o /usr/lib/gcc/i686-linux-gnu/4.7/../../../i386-linux-gnu/crtn.o
/usr/bin/ld: error: cannot open /usr/lib/gcc/i686-linux-gnu/4.7/../../../i386-linux-gnu/libGL.so: No such file or directory

经过一堆挖掘,事实证明我是悬空符号链接的受害者(这基本上是一个没有链接到有效内容的符号链接)。所以发生的事情是链接器在/usr/lib/i386-linux-gnu/libGL.so处发现了一个libGL.so,并决定它的搜索已经结束,但是当它试图获取文件时,符号链接的末尾没有任何内容导致我看到的错误消息。一旦我删除了悬空的符号链接,搜索就没有找到libGL.so,直到它/usr/lib/libGL.so到达正确的版本,此时一切都按预期工作。

由于某种原因,您的库路径似乎未设置。您的配置是否可以选择 --libexecdir=/usr/lib。我有类似的问题,缺少 --libexecdir 的这个选项。

您可以通过在生成文件中传递 LDFLAG 来修复它。如何在makefile中使用LDFLAGS在这里被解脱。你使用 -L/usr/lib 的选项也是完美的。

我刚刚遇到了类似的问题,当时gcc需要一个明确的-L/usr/lib库搜索选项;即使它应该已经在默认的库搜索路径中。奇怪的是,所有库都可用,ldconfig也正确定位了它们。

多亏@radman发现,我记得创建了一个指向最初安装在 /usr/lib 中的 .a 静态库的符号链接,但是当我追逐其他一些配置/构建问题时,我为它添加了一个符号链接到/usr/lib/i386-linux-gnu中。

删除该符号链接(有效,而不是悬空)清除了库搜索问题,因此 gcc 在没有显式-L/usr/lib的情况下正确找到库