Linux/Centos下/lib64/libc.so.6: version `GLIBC_2.14' not found

本文讲述在CentOS系统中,因程序运行需要GLIBC_2.14但系统不存在而出现错误的解决办法。强调升级GLIBC库有风险,可能影响系统运行。给出了在低版本系统编译产品、用高版本系统编译并制作安装包、利用容器技术等建议,还详细介绍了升级到GLIBC 2.15的步骤。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

原文地址:https://blog.youkuaiyun.com/sole_cc/article/details/51415940

 

前天,在Centos的某个版本下编译了一个可执行程序,复制到另外一个Centos环境下去执行,结果出现了以下错误:

/lib64/libc.so.6: version `GLIBC_2.14' not found

貌似是一个很普遍的错误,去网上搜集了相关的资料并整理了一下

 

出现这种错误表明程序运行需要GLIBC_2.14,但是系统中却并不存在,因此可以先用strings命令查看下系统中的GLIBC版本

strings /lib64/libc.so.6 | grep GLIBC

发现系统中最高只支持GLIBC_2.12,解决这个问题有多种方法。

 

在你准备升级GLIBC库之前,你要好好思考一下,
你真的要升级GLIBC么?
你知道你自己在做什么么?
http://baike.baidu.com/view/1323132.htm?fr=aladdin

glibc是gnu发布的libc库,即c运行库。glibc是linux系统中最底层的api,几乎其它任何运行库都会依赖于glibc。glibc除了封装linux操作系统所提供的系统服务外,它本身也提供了许多其它一些必要功能服务的实现…
总的来说,不说运行在linux上的一些应用,或者你之前部署过的产品,就是很多linux的基本命令,比如cp, rm, ll之类,都得依赖于它
网上很多人有惨痛教训,甚至升级失败后系统退出后无法重新进入了。。。。。。

对于CentOS这样的系统,为了追求稳定性(这个值得商榷)往往各种库版本都很低,比如6.5甚至7.0自带的还是glibc2.12, 而ubuntu 14.04带glibc2.19
如果升级基本C运行库到一个太新的版本,可能会影响CentOS的运行。所以大家如果遇到CentOS基本库的问题,影响了自己程序的运行,应该可以考虑:
1. 在低版本的系统编译自己的产品,如果自己的产品确实不需要新版才支持的新特性
2. 用版本高的系统来编译,比如ubuntu,和centos的新版,但可能需要部署到较低版本,那么可以考虑用mock等技术制作更好的安装包,把依赖打入包内
3.利用容器技术,如Docker,在低版本的操作系统内,轻量级的隔离出一个虚拟运行环境,适应你的程序。
好在我遇到的问题是glibc2.15就满足要求升级后暂时没发现问题,所以大家可以参考我的方法:
首先查看现有的情况,在CentOS6.5下

ll /lib64/libc.so.6

libc.so.6是一个软连接,当前的glibc是2.12版本,我遇到的是GLIBC_2.15找不到的问题,所以需至少升级到2.15
首先,从网上下载glibc 2.15的rpm安装包,但这个不容易,因为.rpm针对的是centOS和redhat,高版本安装包很少见。也可以直接从其他系统上拷一个编译好的文件libc.so.6(对应glibc 2.15或者更高的),不过最保险的方式就是下载源代码在本地编译一次(有的人实在编译不成功,那也只能从别的地方找一份了)
各个版本的glibc可以从http://ftp.gnu.org/gnu/glibc/找,包括其插件glibc-port
最新到2.20,我保守的选择2.15
对于低版本glibc,还有glibc-linuxthreads-2.x需要编译,可参考很多网上文档,但2.15没有,所以不用了

 

[plain] view plain copy

  1. wget http://ftp.gnu.org/gnu/glibc/glibc-2.15.tar.gz  
  2.    
  3. wget http://ftp.gnu.org/gnu/glibc/glibc-ports-2.15.tar.gz  
  4.    
  5. tar -xvf  glibc-2.15.tar.gz  
  6.    
  7. tar -xvf  glibc-ports-2.15.tar.gz  
  8.    
  9. mv glibc-ports-2.15 glibc-2.15/ports  
  10.    
  11. mkdir glibc-build-2.15   
  12.    
  13.    
  14. cd glibc-build-2.15  
  15.    
  16.    
  17. ../glibc-2.15/configure  --prefix=/usr --disable-profile --enable-add-ons --with-headers=/usr/include --with-binutils=/usr/bin  
  18.    
  19.    
  20. make  
  21. make install  

如果make遇到了 configure: error: you must configure in a separate build directory

这个只要回到上一级目录执行 configure 就可以了:

 
  1. [root@localhost glibc-2.14]# cd ../

  2. [root@localhost opt]# ./glibc-2.14/configure

如果提示install成功,去看glibc所在的共享库:

可以看到2.12的旧库文件还在,多了2.15版本的库文件,而且软链接文件全部指向了2.15版本。

[plain] view plain copy

  1. -rwxr-xr-x  1 root root 1921096 Aug 30 02:16 /lib64/libc-2.12.so  
  2. -rwxr-xr-x  1 root root 9801632 Sep 25 13:46 /lib64/libc-2.15.so  
  3. lrwxrwxrwx. 1 root root      18 May 19 18:51 /lib64/libcap-ng.so.0 -> libcap-ng.so.0.0.0  
  4. -rwxr-xr-x. 1 root root   18672 Jun 25  2011 /lib64/libcap-ng.so.0.0.0  
  5. lrwxrwxrwx. 1 root root      14 May 19 18:51 /lib64/libcap.so.2 -> libcap.so.2.16  
  6. -rwxr-xr-x  1 root root   19016 Dec  8  2011 /lib64/libcap.so.2.16  
  7. lrwxrwxrwx. 1 root root      19 May 19 18:57 /lib64/libcgroup.so.1 -> libcgroup.so.1.0.40  
  8. -rwxr-xr-x  1 root root   97016 Dec  9  2013 /lib64/libcgroup.so.1.0.40  
  9. -rwxr-xr-x  1 root root  197064 Aug 30 02:16 /lib64/libcidn-2.12.so  
  10. -rwxr-xr-x  1 root root  267972 Sep 25 13:46 /lib64/libcidn-2.15.so  
  11. lrwxrwxrwx  1 root root      15 Sep 25 13:52 /lib64/libcidn.so.1 -> libcidn-2.15.so  
  12. lrwxrwxrwx. 1 root root      17 May 19 18:51 /lib64/libcom_err.so.2 -> libcom_err.so.2.1  
  13. -rwxr-xr-x  1 root root   17256 Nov 22  2013 /lib64/libcom_err.so.2.1  
  14. -rwxr-xr-x  1 root root   40400 Aug 30 02:16 /lib64/libcrypt-2.12.so  
  15. -rwxr-xr-x  1 root root  142947 Sep 25 13:46 /lib64/libcrypt-2.15.so  
  16. lrwxrwxrwx. 1 root root      22 May 19 18:57 /lib64/libcryptsetup.so.1 -> libcryptsetup.so.1.1.0  
  17. -rwxr-xr-x  1 root root   97072 Jun 22  2012 /lib64/libcryptsetup.so.1.1.0  
  18. lrwxrwxrwx  1 root root      16 Sep 25 13:52 /lib64/libcrypt.so.1 -> libcrypt-2.15.so  
  19. lrwxrwxrwx  1 root root      12 Sep 25 13:52 /lib64/libc.so.6 -> libc-2.15.so  

有些人会在make install后出现error。这儿error我没去细究,此时可以查看一下系统此时的GLIBC版本,参考一开始的做法。如果版本未升级,我们只能手动安装一下:

 

首先make是成功了,那么我们会发现build目录下编译出了一个新的libc.so.6 (/glibc-build-2.15/libc.so.6, 我们会发现这实际上也是一个软连接,真实的lib文件是libc.so, 输出

 

[plain] view plain copy

  1. $ ll  libc.so.6  
  2. lrwxrwxrwx 1 root root 7 Sep 23 07:41 libc.so.6 -> libc.so  
  3. [usr@linux glibc-build-2.15]$ strings libc.so | grep GLIBC  
  4. GLIBC_2.2.5  
  5. GLIBC_2.2.6  
  6. GLIBC_2.3  
  7. GLIBC_2.3.2  
  8. GLIBC_2.3.3  
  9. GLIBC_2.3.4  
  10. GLIBC_2.4  
  11. GLIBC_2.5  
  12. GLIBC_2.6  
  13. GLIBC_2.7  
  14. GLIBC_2.8  
  15. GLIBC_2.9  
  16. GLIBC_2.10  
  17. GLIBC_2.11  
  18. GLIBC_2.12  
  19. GLIBC_2.13  
  20. GLIBC_2.14  
  21. GLIBC_2.15  
  22. GLIBC_PRIVATE  

这是我们需要的lib了,然后去更新系统的库。
这里要注意,更新系统里的链接(我的是/lib64/libc.so.6) 很容易出错,我不清楚有没有更好的办法,一般都是删除旧链接,建立新链接
但删除旧链接后,很多命令直接不能用了,因为此时系统中不到glibc的库了。这个时候就需要临时指定一个glibc库,方法如下(libc.so改个名以便好与以后更新的其他版本区分):

 

[plain] view plain copy

  1. cp /****/glibc-build-2.15/libc.so /lib64/libc-2.15.so  
  2. rm -rf /lib64/libc.so.6  
  3. LD_PRELOAD=/lib64/libc-2.15.so ln -s/lib64/libc-2.15.so  lib64/libc.so.6  


更新连接完毕,然后

 

[plain] view plain copy

  1. $ strings /lib64/libc.so.6 | grep GLIBC  
  2. GLIBC_2.2.5  
  3. GLIBC_2.2.6  
  4. GLIBC_2.3  
  5. GLIBC_2.3.2  
  6. GLIBC_2.3.3  
  7. GLIBC_2.3.4  
  8. GLIBC_2.4  
  9. GLIBC_2.5  
  10. GLIBC_2.6  
  11. GLIBC_2.7  
  12. GLIBC_2.8  
  13. GLIBC_2.9  
  14. GLIBC_2.10  
  15. GLIBC_2.11  
  16. GLIBC_2.12  
  17. GLIBC_2.13  
  18. GLIBC_2.14  
  19. GLIBC_2.15  
  20. GLIBC_PRIVATE  

说明连接更新成功,再编译的话,GLIBC_2.15及以下版本的依赖问题就不会出现了。

### 解决 CentOS 上运行 Postman 时遇到的 GLIBC_2.34 版本缺失问题 当在 CentOS 上尝试启动 Postman 并遭遇 `libc.so.6: version 'GLIBC_2.34' not found` 错误时,这表明当前系统的 GNU C Library (glibc) 版本低于所需版本。由于直接升级整个操作系统的 glibc 可能带来兼容性和稳定性风险,推荐采用更为安全的方法来解决问题。 #### 方法一:安装较新版本的 glibc 而不覆盖原有库 可以考虑在一个隔离环境中部署更高版本的 glibc 库,而不影响系统默认设置。具体做法是从源码编译并安装到指定目录下: ```bash mkdir ~/new_glibc && cd $_ wget https://ftp.gnu.org/gnu/libc/glibc-2.34.tar.gz tar -xf glibc-2.34.tar.gz cd glibc-2.34 mkdir build && cd $_ ../configure --prefix=/opt/glibc-2.34 make -j$(nproc) sudo make install ``` 完成上述步骤之后,在执行 Postman 前临时切换至新的 glibc 环境变量路径: ```bash export LD_LIBRARY_PATH=/opt/glibc-2.34/lib:$LD_LIBRARY_PATH ./path/to/postman ``` 这种方法允许在同一台机器上共存多个不同版本的 glibc,并通过调整环境变量的方式灵活选用特定应用所需的版本[^1]。 #### 方法二:利用容器化技术绕过依赖冲突 另一种解决方案是借助 Docker 容器创建一个包含最新 glibc 的独立运行空间。这种方式不仅能够有效规避因更新核心组件而引发的风险,还能简化应用程序及其依赖项的一致性管理。基于前述案例的经验,可以选择支持 glibc 的 Alpine 镜像作为基础镜像构建自定义镜像,从而满足 Postman 对高版本 glibc 的需求[^2]: ```dockerfile FROM frolvlad/alpine-glibc RUN apk add --no-cache libstdc++ fontconfig ttf-dejavu ADD postman /usr/local/bin/ ENV POSTMAN_LAUNCHER=1 \ ELECTRON_RUN_AS_NODE=true CMD ["postman"] ``` 以上两种方案均可有效地处理 CentOS 下缺少 GLIBC_2.34 导致的应用程序无法正常工作的状况。选择哪种方式取决于实际场景和个人偏好。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值