对于低版本glibc,还有glibc-linuxthreads-2.x需要编译,可参考很多网上文档,但2.15没有,所以不用了
如果提示install成功,去看glibc所在的共享库:
这里要注意,更新系统里的链接(我的是/lib64/libc.so.6) 很容易出错,我不清楚有没有更好的办法,一般都是删除旧链接,建立新链接
但删除旧链接后,很多命令直接不能用了,因为此时系统中不到glibc的库了。这个时候就需要临时指定一个glibc库,方法如下(libc.so改个名以便好与以后更新的其他版本区分):
更新连接完毕,然后
-
wget http: //ftp.gnu.org/gnu/glibc/glibc-2.15.tar.gz
-
-
wget http: //ftp.gnu.org/gnu/glibc/glibc-ports-2.15.tar.gz
-
-
tar -xvf glibc -2.15.tar.gz
-
-
tar -xvf glibc-ports -2.15.tar.gz
-
-
mv glibc-ports -2.15 glibc -2.15/ports
-
-
mkdir glibc-build -2.15
-
-
-
cd glibc-build -2.15
-
-
-
../glibc -2.15/configure --prefix= /usr --disable-profile --enable-add-ons --with-headers=/usr/include -- with-binutils= /usr/bin
-
-
-
make
-
make install
如果提示install成功,去看glibc所在的共享库:
可以看到2.12的旧库文件还在,多了2.15版本的库文件,而且软链接文件全部指向了2.15版本。
-
-rwxr-xr-x 1 root root 1921096 Aug 30 02:16 /lib64/libc-2.12.so
-
-rwxr-xr-x 1 root root 9801632 Sep 25 13:46 /lib64/libc-2.15.so
-
lrwxrwxrwx. 1 root root 18 May 19 18:51 /lib64/libcap-ng.so.0 -> libcap-ng.so.0.0.0
-
-rwxr-xr-x. 1 root root 18672 Jun 25 2011 /lib64/libcap-ng.so.0.0.0
-
lrwxrwxrwx. 1 root root 14 May 19 18:51 /lib64/libcap.so.2 -> libcap.so.2.16
-
-rwxr-xr-x 1 root root 19016 Dec 8 2011 /lib64/libcap.so.2.16
-
lrwxrwxrwx. 1 root root 19 May 19 18:57 /lib64/libcgroup.so.1 -> libcgroup.so.1.0.40
-
-rwxr-xr-x 1 root root 97016 Dec 9 2013 /lib64/libcgroup.so.1.0.40
-
-rwxr-xr-x 1 root root 197064 Aug 30 02:16 /lib64/libcidn-2.12.so
-
-rwxr-xr-x 1 root root 267972 Sep 25 13:46 /lib64/libcidn-2.15.so
-
lrwxrwxrwx 1 root root 15 Sep 25 13:52 /lib64/libcidn.so.1 -> libcidn-2.15.so
-
lrwxrwxrwx. 1 root root 17 May 19 18:51 /lib64/libcom_err.so.2 -> libcom_err.so.2.1
-
-rwxr-xr-x 1 root root 17256 Nov 22 2013 /lib64/libcom_err.so.2.1
-
-rwxr-xr-x 1 root root 40400 Aug 30 02:16 /lib64/libcrypt-2.12.so
-
-rwxr-xr-x 1 root root 142947 Sep 25 13:46 /lib64/libcrypt-2.15.so
-
lrwxrwxrwx. 1 root root 22 May 19 18:57 /lib64/libcryptsetup.so.1 -> libcryptsetup.so.1.1.0
-
-rwxr-xr-x 1 root root 97072 Jun 22 2012 /lib64/libcryptsetup.so.1.1.0
-
lrwxrwxrwx 1 root root 16 Sep 25 13:52 /lib64/libcrypt.so.1 -> libcrypt-2.15.so
-
lrwxrwxrwx 1 root root 12 Sep 25 13:52 /lib64/libc.so.6 -> libc-2.15.so
首先make是成功了,那么我们会发现build目录下编译出了一个新的libc.so.6 (/glibc-build-2.15/libc.so.6, 我们会发现这实际上也是一个软连接,真实的lib文件是libc.so, 输出
-
$ ll libc.so. 6
-
lrwxrwxrwx 1 root root 7 Sep 23 07: 41 libc.so. 6 -& gt; libc.so
-
[usr@linux glibc-build- 2.15]$ strings libc.so | grep GLIBC
-
GLIBC_2. 2.5
-
GLIBC_2. 2.6
-
GLIBC_2. 3
-
GLIBC_2. 3.2
-
GLIBC_2. 3.3
-
GLIBC_2. 3.4
-
GLIBC_2. 4
-
GLIBC_2. 5
-
GLIBC_2. 6
-
GLIBC_2. 7
-
GLIBC_2. 8
-
GLIBC_2. 9
-
GLIBC_2. 10
-
GLIBC_2. 11
-
GLIBC_2. 12
-
GLIBC_2. 13
-
GLIBC_2. 14
-
GLIBC_2. 15
-
GLIBC_PRIVATE
这里要注意,更新系统里的链接(我的是/lib64/libc.so.6) 很容易出错,我不清楚有没有更好的办法,一般都是删除旧链接,建立新链接
但删除旧链接后,很多命令直接不能用了,因为此时系统中不到glibc的库了。这个时候就需要临时指定一个glibc库,方法如下(libc.so改个名以便好与以后更新的其他版本区分):
-
cp /**** /glibc-build-2.15/libc.so /lib64/libc- 2.15.so
-
rm -rf /lib64/libc.so. 6
-
LD_PRELOAD= /lib64/libc- 2.15.so ln - s/lib64/libc-2.15.so lib64/libc.so. 6
更新连接完毕,然后
-
$ strings /lib64/libc.so. 6 | grep GLIBC
-
GLIBC_2. 2.5
-
GLIBC_2. 2.6
-
GLIBC_2. 3
-
GLIBC_2. 3.2
-
GLIBC_2. 3.3
-
GLIBC_2. 3.4
-
GLIBC_2. 4
-
GLIBC_2. 5
-
GLIBC_2. 6
-
GLIBC_2. 7
-
GLIBC_2. 8
-
GLIBC_2. 9
-
GLIBC_2. 10
-
GLIBC_2. 11
-
GLIBC_2. 12
-
GLIBC_2. 13
-
GLIBC_2. 14
-
GLIBC_2. 15
-
GLIBC_PRIVATE
说明连接更新成功,再编译的话,GLIBC_2.15及以下版本的依赖问题就不会出现了。
还有更新2.17的 操作方法一样 版本换一下 strings /lib64/libc.so.6 | grep GLIBC 查看一下版本
然后启动zabbix就可以了