Linux/CentOS 升級C基本運行庫CLIBC的注意事項(當想解決GLIBC_2.x找不到的編譯問題)__Linux

來源:互聯網
上載者:User
標籤: GLIBCcentoslinux基礎運行庫 2014-09-24 10:32 23013人閱讀 評論(21) 收藏 舉報 分類: 開發環境(8) Linux(3)

著作權聲明:本文為博主原創文章,未經博主允許不得轉載。

在你準備升級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下 [plain] view plain copy $ ll /lib64/libc.so.6   lrwxrwxrwx 1 root root 19 Sep 23 08:29 /lib64/libc.so.6 -> /lib64/libc-2.12.so  

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 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    [plain] view plain copy make install  

如果提示install成功,去看glibc所在的共用庫: [plain] view plain copy ll /lib64/libc*  

可以看到2.12的舊庫檔案還在,多了2.15版本的庫檔案,而且軟連結檔案全部指向了2.15版本。 [plain] view plain copy -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 install後出現error。這兒error我沒去細究,經過網友提醒,可能是因為沒有sudo造成的,因為make install就是把檔案拷貝到幾個受保護的系統目錄下。

如果還是不行,可以查看一下系統此時的GLIBC版本,參考一開始的做法。如果版本未升級,我們只能手動安裝一下:

首先make是成功了,那麼我們會發現build目錄下編譯出了一個新的libc.so.6 (/glibc-build-2.15/libc.so.6, 我們會發現這實際上也是一個軟串連,真實的lib檔案時libc.so, 輸出 [html] view plain copy $ ll  libc.so.6   lrwxrwxrwx 1 root root 7 Sep 23 07:41 libc.so.6 -> libc.so   [html] view plain copy [usr@linux glibc-build-2.15]$ strings libc.so | grep GLIBC   [plain] view plain copy 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  


這是我們需要的lib了,然後去更新系統的庫。

這裡要注意,更新系統裡的連結(我的是/lib64/libc.so.6) 很容易出錯,我不清楚有沒有更好的辦法,一般都是刪除舊連結,建立新連結

但刪除舊連結後,很多命令直接不能用了,因為此時中不到glibc的庫了。這個時候就需要臨時指定一個glibc庫,方法如下(libc.so改個名以便好以後更新的其他版本區分): [html] view plain copy [usr@linux cp /****/glibc-build-2.15/libc.so /lib64/libc-2.15.so   [html] view plain copy rm -rf /lib64/libc.so.6   LD_PRELOAD=/lib64/libc-2.15.so ln -s/lib64/libc-2.15.so  lib64/libc.so.6  

更新串連完畢,然後:
[html] view plain copy $ strings /lib64/libc.so.6 | grep GLIBC   [plain] view plain copy 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及以下版本的依賴問題就不會出現了。

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.