c++ - 需要 GLIBC 2.7 版本。使用更高版本的 GLIBC 编译 C++ 代码,同时支持更早的 glibc
问题描述
我有两台机器
- RHEL 4 机器
- RHEL 6 机器
现在我有一个代码,我可以在 RHEL4 机器上编译,然后在两台机器上运行可执行文件。但是如果我在 RHEL6 机器上编译相同的代码,我无法在 RHEL4 机器上运行可执行文件。它会引发错误“需要 GLIBC 2.7 版本”。
现在我的问题是,RHEL6 机器上的 GLIBC 2.7 已经支持早期版本并且具有与早期版本相关的标头。那么我可以以某种方式告诉我的 gcc 编译器使用特定的早期版本的 gcc 来编译代码吗?(因为它可以在早期版本上编译......)
更多信息:
$readelf -a glibc
在 RHEL4 机器上显示,
Addr: 0x0000000000014428 Offset: 0x014428 Link: 4 (.dynstr)
000000: Rev: 1 Flags: BASE Index: 1 Cnt: 1 Name: libc.so.6
0x001c: Rev: 1 Flags: none Index: 2 Cnt: 1 Name: GLIBC_2.2.5
0x0038: Rev: 1 Flags: none Index: 3 Cnt: 2 Name: GLIBC_2.2.6
0x0054: Parent 1: GLIBC_2.2.5
0x005c: Rev: 1 Flags: none Index: 4 Cnt: 2 Name: GLIBC_2.3
0x0078: Parent 1: GLIBC_2.2.6
0x0080: Rev: 1 Flags: none Index: 5 Cnt: 2 Name: GLIBC_2.3.2
0x009c: Parent 1: GLIBC_2.3
0x00a4: Rev: 1 Flags: none Index: 6 Cnt: 2 Name: GLIBC_2.3.3
0x00c0: Parent 1: GLIBC_2.3.2
0x00c8: Rev: 1 Flags: none Index: 7 Cnt: 2 Name: GLIBC_2.3.4
0x00e4: Parent 1: GLIBC_2.3.3
0x00ec: Rev: 1 Flags: none Index: 8 Cnt: 2 Name: GLIBC_PRIVATE
0x0108: Parent 1: GLIBC_2.3.4
$readelf -a glibc 在 RHEL6 机器上显示,
版本定义部分 '.gnu.version_d' 包含 17 个条目:
Addr: 0x00000031b2a16eb8 Offset: 0x016eb8 Link: 5 (.dynstr)
000000: Rev: 1 Flags: BASE Index: 1 Cnt: 1 Name: libc.so.6
0x001c: Rev: 1 Flags: none Index: 2 Cnt: 1 Name: GLIBC_2.2.5
0x0038: Rev: 1 Flags: none Index: 3 Cnt: 2 Name: GLIBC_2.2.6
0x0054: Parent 1: GLIBC_2.2.5
0x005c: Rev: 1 Flags: none Index: 4 Cnt: 2 Name: GLIBC_2.3
0x0078: Parent 1: GLIBC_2.2.6
0x0080: Rev: 1 Flags: none Index: 5 Cnt: 2 Name: GLIBC_2.3.2
0x009c: Parent 1: GLIBC_2.3
0x00a4: Rev: 1 Flags: none Index: 6 Cnt: 2 Name: GLIBC_2.3.3
0x00c0: Parent 1: GLIBC_2.3.2
0x00c8: Rev: 1 Flags: none Index: 7 Cnt: 2 Name: GLIBC_2.3.4
0x00e4: Parent 1: GLIBC_2.3.3
0x00ec: Rev: 1 Flags: none Index: 8 Cnt: 2 Name: GLIBC_2.4
0x0108: Parent 1: GLIBC_2.3.4
0x0110: Rev: 1 Flags: none Index: 9 Cnt: 2 Name: GLIBC_2.5
0x012c: Parent 1: GLIBC_2.4
0x0134: Rev: 1 Flags: none Index: 10 Cnt: 2 Name: GLIBC_2.6
0x0150: Parent 1: GLIBC_2.5
0x0158: Rev: 1 Flags: none Index: 11 Cnt: 2 Name: GLIBC_2.7
0x0174: Parent 1: GLIBC_2.6
0x017c: Rev: 1 Flags: none Index: 12 Cnt: 2 Name: GLIBC_2.8
0x0198: Parent 1: GLIBC_2.7
0x01a0: Rev: 1 Flags: none Index: 13 Cnt: 2 Name: GLIBC_2.9
0x01bc: Parent 1: GLIBC_2.8
0x01c4: Rev: 1 Flags: none Index: 14 Cnt: 2 Name: GLIBC_2.10
0x01e0: Parent 1: GLIBC_2.9
0x01e8: Rev: 1 Flags: none Index: 15 Cnt: 2 Name: GLIBC_2.11
0x0204: Parent 1: GLIBC_2.10
0x020c: Rev: 1 Flags: none Index: 16 Cnt: 2 Name: GLIBC_2.12
0x0228: Parent 1: GLIBC_2.11
0x0230: Rev: 1 Flags: none Index: 17 Cnt: 2 Name: GLIBC_PRIVATE
0x024c: Parent 1: GLIBC_2.12
那么有没有办法可以使用 GLIBC 2.3.4 头文件在 RHEL6 上编译代码。因为我没有使用 GLIBC 2.3.4 中没有的任何新东西
解决方案
让我们确认一下 RHEL 上的默认 glibc 版本。来自RHEL 的distrowatch:
- RHEL 4 有 glibc 2.3.4
- RHEL 6 有 glibc 2.12
我无法在 RHEL4 机器上运行可执行文件。它会引发错误“需要 GLIBC 2.7 版本”。
自 2.3.4 以来,glibc 中有更新的符号版本在 2.12 中,但在 2.3.4 中没有。所以这是预期的,不会起作用。
现在我的问题是,RHEL6 机器上的 GLIBC 2.7 已经支持早期版本并且具有与早期版本相关的标头。
是的。但是当您使用 glibc 2.12 进行编译时,它可能会使用旧 glibc 版本中没有的符号。
那么我可以以某种方式告诉我的 gcc 编译器使用特定的早期版本的 gcc 来编译代码吗?
这是编译器 - gcc - 这就是这里的问题。它是 glibc 库。即使您在带有 glibc 2.12 的系统上安装了较旧的 gcc,您仍然会遇到同样的问题。
那么有没有办法可以使用 GLIBC 2.3.4 头文件在 RHEL6 上编译代码。因为我没有使用 GLIBC 2.3.4 中没有的任何新东西
同样,您混淆了很多东西-标题不是问题。它是 glibc 库,特别是它使用的新符号。“你”可能没有使用任何特定于 glibc 2.12 的东西,但可能会自动引入更新的符号。显然,这就是你的情况。
我不确定你为什么要这样做。如果您对 RHEL 4 (glibc 2.3.4) 感到满意,那么为什么要在其上编译并在 RHEL 6 上使用它 - 因为较新的 glibc 将具有较旧的符号。
推荐阅读
- latex - 当内容大小增加时,如何防止带有 \hline 的长表在新页面上开始?
- c++ - 在OpenGL中从上方移动相机
- python - 需要帮助在 python 上将底图转移到 cartopy
- javascript - 包全局配置 NPM 库
- operating-system - 计算机 CPU 如何执行软件应用程序
- progressive-web-apps - 使用 workbox-cli 设置 service worker 后应该将哪些文件添加到版本控制中
- r - 使用 RSelenium 寻找灵活的元素
- c# - 将 Polly 与 EF Core 3.1 一起使用
- google-cloud-platform - Google Cloud API 凭据消失了
- multithreading - gRPC Java 客户端能否通过长期存在的 gRPC 流并行发送多个请求以及如何管理 N 个流