在Linux中,为什么标准库需要存根?
需要存根以确保在各种Linux版本之间正确链接可执行文件,而无需构建目标文件。
例如:让a为我们正在构建的可执行文件:
gcc -o a test.o test1.o test2.o -lz
在上述情况下,可执行文件a依赖libz.so(-lz即与libz.so链接)。链接器使用LD_LIBRARY_PATH解析libz.so。
-lz
现在让我们看看问题所在:
In RHEL4(Linux Zseries): objdump -T /usr/lib64/libz.so.1 | grep stack_chk In RHEL5(Linux ZSeries); objdump -T /usr/lib64/libz.so.1 | grep stack_chk 0000000000000000 DF UND 0000000000000031 GLIBC_2.4 __stack_chk_fail
在RHEL5中,我们在libz.so中看到一个未定义的符号。除非我们在上述命令中的lz之后将libc传递给链接器,否则无法解决。
存根:如果我们为libz.so生成存根,将libz.so的所有符号打包到存根库中,并与存根库而不是真实库链接,则不会看到任何错误:
修改后的链接行:
gcc -o a test.o test1.o test2.o -L/home/lib/stubs/ -lz
在/ home / lib / stubs目录中,我们有一个名为libzstub.so的libz.so存根库。
链接程序对链接命令中给出的路径的优先级高于LD_LIBRARY_PATH。
现在,即使我们在RHEL5版本中进行链接,链接器也会从/ home / lib / stubs目录中解析libz.so的符号。
在这里,我使用了盒子的配置细节。
加载程序负责在运行时加载核心响应函数。
RHEL5:
libcmpiutil-0.4-2.el5 glibc-utils-2.5-42 libc-client-2004g-2.2.1 libcap-1.10-26 libcap-1.10-26 libchewing-devel-0.3.0-8.el5 libchewing-0.3.0-8.el5 libcxgb3-1.2.3-1.el5 libcap-devel-1.10-26 glibc-common-2.5-42 libcxgb3-static-1.2.3-1.el5 libcroco-devel-0.6.1-2.1 compat-glibc-headers-2.3.4-2.26 libcroco-0.6.1-2.1 compat-libcom_err-1.0-7 libcmpiutil-devel-0.4-2.el5 compat-glibc-2.3.4-2.26 glibc-headers-2.5-42 glibc-devel-2.5-42 libcap-devel-1.10-26 libc-client-2004g-2.2.1 libcmpiutil-0.4-2.el5 libcroco-0.6.1-2.1 libc-client-devel-2004g-2.2.1 glibc-2.5-42 libchewing-devel-0.3.0-8.el5 libcroco-devel-0.6.1-2.1 compat-libcom_err-1.0-7 libc-client-devel-2004g-2.2.1 libchewing-0.3.0-8.el5 libcxgb3-1.2.3-1.el5 libcmpiutil-devel-0.4-2.el5 glibc-2.5-42 glibc-devel-2.5-42 compat-glibc-2.3.4-2.26
RHEL4:
rpm -qa | grep libc glibc-2.3.4-2.41 libcxgb3-1.1.4-1.el4 libc-client-2002e-14 libcroco-0.6.0-4 libcap-devel-1.10-20 glibc-kernheaders-2.4-9.1.103.EL compat-libcom_err-1.0-5 glibc-devel-2.3.4-2.41 compat-glibc-2.3.2-95.30 compat-libcom_err-1.0-5 glibc-common-2.3.4-2.41 libcroco-devel-0.6.0-4 libcxgb3-1.1.4-1.el4 libc-client-2002e-14 glibc-utils-2.3.4-2.41 libcap-1.10-20 glibc-headers-2.3.4-2.41 glibc-profile-2.3.4-2.41 libcxgb3-static-1.1.4-1.el4 glibc-devel-2.3.4-2.41 compat-glibc-2.3.2-95.30