- mongodb - 在 MongoDB mapreduce 中,如何展平值对象?
- javascript - 对象传播与 Object.assign
- html - 输入类型 ="submit"Vs 按钮标签它们可以互换吗?
- sql - 使用 MongoDB 而不是 MS SQL Server 的优缺点
大多数在线资源表明您可以静态链接 glibc,但不鼓励这样做;例如centos package repo :
The glibc-static package contains the C library static librariesfor -static linking. You don't need these, unless you link statically, which is highly discouraged.
这些消息来源很少(或从不)说明为什么这是一个坏主意。
最佳答案
其他答案给出的理由是正确的,但不是最重要的原因。
glibc 不应该被静态链接的最重要原因是它在内部大量使用了dlopen
。 , 加载 NSS ( Name Service Switch ) 模块和 iconv
转换。模块本身引用 C 库函数。如果主程序与 C 库动态链接,那没问题。但如果主程序与 C 库静态链接,dlopen
必须去加载 C 库的第二个拷贝以满足模块的加载要求。
这意味着你的“静态链接”程序仍然需要一个 libc.so.6
的拷贝出现在文件系统上,加上 NSS 或 iconv
或其他任何东西模块本身,加上模块可能需要的其他动态库,如 ld-linux.so.2
、libresolv.so.2
等。这不是人们通常的当他们静态链接程序时需要。
这也意味着静态链接的程序在其地址空间中有两个 C 库拷贝,它们可能会争夺使用谁的 stdout
缓冲区,谁可以调用 sbrk
带有非零参数,诸如此类。 glibc 内部有一堆防御性逻辑试图让这项工作发挥作用,但从来没有保证能够工作。
您可能认为您的程序不需要担心这一点,因为它从不调用 getaddrinfo
或 iconv
,但语言环境支持使用 iconv
内部,这意味着 任何 stdio.h
函数 都可能触发对 dlopen
的调用,而您无法控制它,用户的环境变量设置。
如果你的程序确实调用iconv
,那么事情会变得更糟,尤其是当“静态链接”的可执行文件构建在一个发行版上时,然后复制到另一个。 iconv
模块有时位于不同发行版的不同位置,因此在 Red Hat 发行版上构建的可执行文件可能无法在 Debian 上正常运行,这与人们想从静态链接的可执行文件中得到什么。
关于c++ - 为什么不鼓励静态链接 glibc?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/57476533/
这个问题在这里已经有了答案: Multiple glibc libraries on a single host (11 个回答) 5年前关闭。 有没有办法在本地文件夹中安装新版本的 GLIBC?我将
这个问题在这里已经有了答案: Deploying Yesod to Heroku, can't build statically (4 个回答) 1年前关闭。 我有两台机器 RHEL 4机 RHEL
我在 C 启动时读取 article ,它指的是函数 __libc_csu_init 。谁能告诉我CSU代表什么? 最佳答案 我在 libc p 中找到了对“ C s tart u p”的引用。 这远
我正在使用 AlpineLinux(安装在我的计算机上,而不是安装在 docker 中)并且我正在尝试使用依赖于 glibc 的共享库。 由于 Glibc 没有集成到这个发行版中,我看到开发了一个替代
所以我正在玩 Alpine Linux,它使用 musl 与 glibc。 我发现由于这个选择,我无法运行 Oracle Java 或在 glibc 下构建的静态二进制文件。 musl 是否应该与更广
在构建 glibc 时,出现此错误。 *glibc/build/elf/dl-allobjs.os: file not recognized: File format not recognized c
我一直在寻找没有好的结果。 我想知道在文本中解释为 Malloc Maleficarum 或 Malloc Des-Malleficarum 的技术在 glibc 2.12.1 版本中是否有效。 在提
我在 CentOS 上安装 gcc 时遇到问题。 我的命令的输出sudo yum install gcc: Loaded plugins: fastestmirror Loading mirror s
我想下载gzip类型的mariadb,但是我发现它有很多文件可以下载,例如mariadb-10.2.6-linux-x86_64.tar.gz,mariadb-10.2.6-linux-glibc_2
我想尝试使用不同的 glibc 的 sin 函数。他们是否可以在不编译整个 glibc 的情况下使用不同 glibc 版本的 sin 函数? 我已经在我的虚拟 ubuntu 机器上下载了不同版本的 g
我要在超算中心的目录下安装一个软件,但是sudo,root,连apt-get,yum都不能用...这个软件需要glibc2.7,所以我得手动安装gcc和glibc(因为我无法更改内置 gcc 的路径来
我正在研究需要在多个不同的嵌入式平台上运行的 C 和 C++ 程序,为此我有交叉编译器,因此我可以在我的 x86 桌面上进行构建。 我在某些功能上遇到了一个可怕的问题,例如“strtod()”。这是我
我遇到了一个非常烦人的问题:我有一个程序,它在开始时创建一个线程,该线程将在执行期间启动其他内容(fork() 紧随其后的是 execve())。 这是我的程序达到(我认为)死锁时两个线程的 bt:
我刚刚发现,glibc 2.23 有一个关于 stdio 函数 fmemopen() 的错误,参见例如Using rewind() on a FILE* opened with fmemopen .
[root@localhost Keystone2]# sudo rpm -ivh glibc-2.3.4-2.9.audit.x86_64.rpm --nodeps --force warning:
从该系列中很容易找到如何使用 dlsym()和其他函数,但是在内部如何工作呢?是否可以编写自己的,容易实现的dlsym()? 我想知道是否有可能实现类似的行为,但在不将与-ldl链接的情况下实现(可以
嗨,我目前使用的是 ubuntu 9.10 和 glibc 版本 2.11.1-0,好吧,我正在做一个项目,我想用 glibc 的另一个版本(2.5-58)进行测试,我想知道以下与此相关的事情: 如何
我已经下载了glibc,这样我就可以修改它的代码然后使用它。所以只是为了玩玩它,我更改了 glibc 的 stdio-common 目录中的 printf 函数,以便它打印“你可以看到我吗?”。 in
我正在集群上的 conda 环境中部署 R 脚本。该脚本加载了一些需要 glibc 版本 >= 2.14 的包。虽然我的系统的 glibc 版本为 2.14,但集群的 glibc 版本为 2.12,我
所以。我有一个问题,我在一台机器上有两个版本的 GCC。 3.4.6 和 4.1 这是由于新软件的一些依赖性问题。 (需要 glibc 4.1) 当我将这个新软件与 4.1 库链接时,它链接得很好。但
我是一名优秀的程序员,十分优秀!