这几天升级线上版本,遇到一个glibc版本不一致的问题,导致服务无法升级,坑了我好快两天。把这个记录下来方便其他遇到问题的小伙伴可以参考下:
1) 问题现象 :启动的时候
“/lib64/libc.so.6: version `GLIBC_2.14' not found (required by“
2)查看本地和线上的glibc的版本是否一致:
ldd --version 可以查看下本地的glibc和线上的glibc版本
由于线上机器系统版本不一样,glibc的版本也不完全一致,一般2.12、2.14、2.17的版本比较多,高版本会兼容低版本
4)查看哪些函数使用了高版本的glibc
strings debug-edge | grep "GLIBC_2.14"
在这里可以看到是memcpy这个使用了glibc版本
或者使用readelf命令查看
5)常见解决办法:
一般情况出问题的是编译的时候用了高版本,但是线上用的是低版本的glibc。例如编译的时候用了glibc 2.17, 线上用的版本是
glibc 2.12。
第一种:高版本函数替换
查看程序中有哪些函数使用了高版本的glibc库,如果仅仅只是那一两个可以考虑其他函数替换
可以参考这篇文章:https://www.jianshu.com/p/308a4e803c81
第二种:升级glibc版本库
1 安装 wget http://ftp.gnu.org/gnu/glibc/glibc-2.14.tar.gz tar zxvf glibc-2.14.tar.gz cd glibc-2.14 mkdir build cd build/ ../configure --prefix=/opt/glibc-2.14 make -j4 make install export LD_LIBRARY_PATH="/opt/glibc-2.14/lib${LD_LIBRARY_PATH:+:$LD_LIBRARY_PATH}"
2 建立软连接 rm -rf /lib64/libc.so.6 ln -s /opt/glibc-2.14/lib/libc-2.14.so /lib64/libc.so.6
|
如果能一下升级成功那么恭喜你,如果升级过程中遇到各种编译问题,解决这些编译问题说不定能折腾一整天。
建议别再升级了。我这边解决方法是自己本地装个低版本的centos虚拟机可能还更快点,6.9或者6.10的centos系统版本对应默认是glibc 2.12