将libstdc++.so.6与应用程序一起发布
Shipping libstdc++.so.6 with application
我想在我的应用程序中使用 gcc 4.8.1(需要 libstdc++.so.6.0.18(,但是客户只有 libstdc++.so.6.0.13。我已经使用 -static-libgcc -static-stdlibc++
一段时间了,但我的应用程序由几个动态链接的库和一个主应用程序组成。 这意味着在编译每个动态库时,他们必须静态编译标准库,这是冗余和浪费的。 我只想随产品一起提供我选择的标准库,但是每次我在像他们这样的环境中运行我的应用程序时,它总是加载错误的标准库。 无论我做什么,它都更喜欢/usr/lib64/
版本(它似乎优先于LD_LIBRARY_PATH
(。
约束:
-
我不允许强迫他们升级到新的标准库。
-
我不想使动态库成为静态的。 (我可以将所有内容静态编译到主应用程序中一次,但是有一些后勤障碍阻止我将某些库重新编译为静态库(。
-Wl,-rpath=$(path_to_directory)
有点危险,但它是合法的,因为客户确实提供了一些允许我设置路径变量的设置。 但是,设置我的新 stdlibc++ 的 rpath 似乎并没有覆盖默认的/usr/lib64
版本。 我仍然收到GLIBCXX
错误,因为它不会使用正确的库。
当然有一个优雅的解决方案吗?
也许我的程序只是有错误。 这是一个例子(对不起审查员,但这只是用户名的东西(:
~/example$ pwd
/home/username/example
~/example$ echo $LD_LIBRARY_PATH
~/example$ ls
Makefile libstdc++.so.6.0.18 test.cpp
~/example$ make
g++ -std=c++11 -Wall -Werror test.cpp -o test
~/example$ ldd test
./test: /usr/lib64/libstdc++.so.6: version `GLIBCXX_3.4.14' not found (required by ./test)
linux-vdso.so.1 => (0x00007fffe5919000)
libstdc++.so.6 => /usr/lib64/libstdc++.so.6 (0x000000390b800000)
libm.so.6 => /lib64/libm.so.6 (0x0000003904800000)
libgcc_s.so.1 => /lib64/libgcc_s.so.1 (0x000000390b400000)
libc.so.6 => /lib64/libc.so.6 (0x0000003904400000)
/lib64/ld-linux-x86-64.so.2 (0x0000003904000000)
~/example$ setenv LD_LIBRARY_PATH /home/username/example
~/example$ echo $LD_LIBRARY_PATH
/home/username/example
~/example$ ldd test
./test: /usr/lib64/libstdc++.so.6: version `GLIBCXX_3.4.14' not found (required by ./test)
linux-vdso.so.1 => (0x00007fff2d3ff000)
libstdc++.so.6 => /usr/lib64/libstdc++.so.6 (0x000000390b800000)
libm.so.6 => /lib64/libm.so.6 (0x0000003904800000)
libgcc_s.so.1 => /lib64/libgcc_s.so.1 (0x000000390b400000)
libc.so.6 => /lib64/libc.so.6 (0x0000003904400000)
/lib64/ld-linux-x86-64.so.2 (0x0000003904000000)
对不起,伙计们,我犯了一个相当愚蠢的错误...
~/example$ file libstdc++.so.6.0.18
libstdc++.so.6.0.18: ELF 32-bit LSB shared object, Intel 80386, version 1 (SYSV), dynamically linked, not stripped
一些 dweeb 构建了错误版本的库,另一个 dweeb(即我自己(尝试在 64 位机器上使用它。 使用LD_LIBRARY_PATH
一直在工作...
您的问题是可执行文件链接到soname libstdc++.so.6
而不是完整的库文件名libstdc++.so.6.0.16
。动态链接器将在通常的位置(即LD_LIBRARY_PATH,DT_RPATH,ldconfig dirs等(查找libstdc++.so.6
,因此为了确保找到6.0.18版本,您需要一个名为libstdc++.so.6
的符号链接指向它。
与其使用 LD_LIBRARY_PATH(这在您无法控制的机器上很脆弱,因为用户可能会改变他们的环境(我更喜欢与'-Wl,-rpath,$ORIGIN'
链接(注意引号对于阻止 shell 扩展$ORIGIN
是必要的(
$ORIGIN
的 RPATH 告诉动态链接器开始在与可执行文件相同的目录中查找共享库,因此,如果您将 libstdc++.so 与可执行文件一起提供,则会找到它。如果要将可执行文件传送到bin
目录中,并将库放在lib
目录中,则可以使用相对于可执行文件位置的'-Wl,-rpath,$ORIGIN/../lib'
或其他路径。
- 试图在visual studio上用C++创建一个桌面应用程序
- FFmpeg:制作一个应用程序比直接使用ffmepg更好吗
- 在C应用程序中运行C++(带有STL)函数
- 使用VerQueryValue检索应用程序的文件描述
- Qt C++静态thread_local QNetworkAccessManager是线程应用程序的好选择吗
- 使用调试/崩溃报告将应用程序部署到客户端
- C++控制台应用程序阻止退出
- 如何将Valgrind与Qt Creator一起使用来调试远程应用程序?
- SWIG和Mingw-64与Python一起使用...不是有效的 Win32 应用程序
- 我可以将OpenCV的Release配置与我的应用程序的Debug配置一起使用吗
- 如何将OpenMP与Qt一起使用,以便应用程序仍然可以点击
- 是否可以将addr2line与使用发布优化参数编译的应用程序一起使用
- 如何将文件与C++应用程序的二进制文件打包在一起
- 与多线程一起登录多进程应用程序
- 将libstdc++.so.6与应用程序一起发布
- 将非本地数据/媒体文件与C++应用程序 (gtkmm) 一起使用
- 如何将c++ dll与C应用程序一起使用?< / h1 >
- 如何将Allegro库与Ubuntu Allegro应用程序捆绑在一起?
- 编译后的.so能与c++应用程序一起工作吗?
- 是否可以将Windows控制台应用程序与Windows GUI应用程序一起运行?