CentOS7升級GCC版本

最近了解到VScode開源后有團隊開發了WEB版的VSCode,叫code-server,于是冒出了在騰訊云或公司服務器上搭建一個code-server方便iPad或其他平板設備只通過瀏覽器就可以進行企業級工程開發的想法。

解壓好code-server在啟動時報錯

/usr/lib64/libstdc++.so.6: version `GLIBCXX_3.4.21' not found

出現這個錯誤是因為CentOS7當前版本默認的GCC的版本太老,里面的動態鏈接庫沒有GLIBCXX_3.4.21。

執行以下命令檢查動態庫:

$ strings /usr/lib64/libstdc++.so.6 | grep GLIBC

輸出結果如下:

GLIBCXX_3.4
GLIBCXX_3.4.1
GLIBCXX_3.4.2
GLIBCXX_3.4.3
GLIBCXX_3.4.4
GLIBCXX_3.4.5
GLIBCXX_3.4.6
GLIBCXX_3.4.7
GLIBCXX_3.4.8
GLIBCXX_3.4.9
GLIBCXX_3.4.10
GLIBCXX_3.4.11
GLIBCXX_3.4.12
GLIBCXX_3.4.13
GLIBCXX_3.4.14
GLIBCXX_3.4.15
GLIBCXX_3.4.16
GLIBCXX_3.4.17
GLIBCXX_3.4.18
GLIBCXX_3.4.19
GLIBC_2.3
GLIBC_2.2.5
GLIBC_2.14
GLIBC_2.4
GLIBC_2.3.2
GLIBCXX_DEBUG_MESSAGE_LENGTH

可以看到確實沒有GLIBCXX_3.4.21

執行以下命令查看當前gcc版本:

$ gcc -v

輸出gcc版本:

gcc version 4.8.5 20150623 (Red Hat 4.8.5-36) (GCC) 

執行命令查看libstdc++.so.6的位置:

$ find / -name libstdc++.so.6*

列出與libstdc++.so.6相關的文件:

/usr/lib64/libstdc++.so.6.0.19
/usr/lib64/libstdc++.so.6
/usr/share/gdb/auto-load/usr/lib64/libstdc++.so.6.0.19-gdb.py
/usr/share/gdb/auto-load/usr/lib64/libstdc++.so.6.0.19-gdb.pyo
/usr/share/gdb/auto-load/usr/lib64/libstdc++.so.6.0.19-gdb.pyc
/data/result/SegParser/libstdc++.so.6
/data/download_record/SegParser/libstdc++.so.6
/data/segdsegy/SegParser/libstdc++.so.6

可以看到當前動態連接庫版本是libstdc++.so.6.0.19。

進入/usr/lib64目錄查看軟鏈接情況:

$ ls -l libstdc++.so*

顯示結果:

lrwxrwxrwx 1 root root     19 Mar 18 11:39 libstdc++.so.6 -> libstdc++.so.6.0.19
-rwxr-xr-x 1 root root 991616 Oct 30 14:39 libstdc++.so.6.0.19

軟鏈接就鏈接到了libstdc++.so.6.0.19這個版本上。

鑒于系統內不存在更高版本的libstdc++.so.6的庫,遂計劃升級GCC版本。

升級GCC版本

安裝開發必備環境:

$ yum groupinstall "Development Tools"
$ yum install glibc-static libstdc++-static

GCC源碼地址為http://ftp.gnu.org/gnu/gcc,里面有GCC的各個版本,請根據各自的需要下載。這里索性選擇了當前最新版本gcc-8.3.0。

找到或創建并進入到一個臨時目錄,執行命令:

$ wget http://ftp.gnu.org/gnu/gcc/gcc-8.3.0/gcc-8.3.0.tar.gz

下載完成之后,解壓文件:

$ tar -zxvf gcc-8.3.0.tar.gz

解壓完成,進入文件目錄:

$ cd gcc-8.3.0

利用源碼包里自帶的工具下載所需要的依賴項:

$ ./contrib/download_prerequisites

創建編譯輸出目錄:

mkdir build

進入build目錄:

$ cd build

生成Makefile:

$ ../configure --enable-checking=release --enable-languages=c,c++ --disable-multilib

編譯:

$ make

make的過程如果遇到如下錯誤:

collect2: ld terminated with signal 9 [Killed]

有可能是主機內存過低造成的,可通過設置swap文件來解決:

$ cd ~
$ mkdir swap
$ cd swap
$ dd if=/dev/zero  of=swapfile  count=4096  bs=1024k
$ chmod 600 swapfile
$ mkswap swapfile
$ swapon swapfile

通過命令:

$ swapon -s //查看swap文件的狀態
$ free -m   //查看內存當前用量

查看swap分區文件的掛載情況。

編譯完成之后,安裝:

$ make install

完成安裝之后,檢查是否安裝成功:

$ gcc -v
Using built-in specs.
COLLECT_GCC=gcc
COLLECT_LTO_WRAPPER=/usr/local/libexec/gcc/x86_64-pc-linux-gnu/8.3.0/lto-wrapper
Target: x86_64-pc-linux-gnu
Configured with: ../configure -enable-checking=release -enable-languages=c,c++ -disable-multilib
Thread model: posix
gcc version 8.3.0 (GCC) 

gcc版本已變成最新版,查看動態庫是否已正常:

$ strings /usr/lib64/libstdc++.so.6 | grep GLIBC

然而發現并沒有,查找編譯gcc時生成的最新動態庫:

$ find / -name "libstdc++.so*"

執行結果如下:

/usr/local/lib64/libstdc++.so.6.0.25
/usr/local/lib64/libstdc++.so
/usr/local/lib64/libstdc++.so.6.0.25-gdb.py
/usr/local/lib64/libstdc++.so.6
/usr/lib64/libstdc++.so.6.0.19
/usr/lib64/libstdc++.so.6
/usr/lib/gcc/x86_64-redhat-linux/4.8.2/libstdc++.so
/usr/lib/gcc/x86_64-redhat-linux/4.8.2/32/libstdc++.so
/usr/share/gdb/auto-load/usr/lib64/libstdc++.so.6.0.19-gdb.py
/usr/share/gdb/auto-load/usr/lib64/libstdc++.so.6.0.19-gdb.pyo
/usr/share/gdb/auto-load/usr/lib64/libstdc++.so.6.0.19-gdb.pyc
/opt/gcc-8.3.0/build/x86_64-pc-linux-gnu/libstdc++-v3/src/.libs/libstdc++.so.6.0.25
/opt/gcc-8.3.0/build/x86_64-pc-linux-gnu/libstdc++-v3/src/.libs/libstdc++.so
/opt/gcc-8.3.0/build/x86_64-pc-linux-gnu/libstdc++-v3/src/.libs/libstdc++.so.6
/opt/gcc-8.3.0/build/stage1-x86_64-pc-linux-gnu/libstdc++-v3/src/.libs/libstdc++.so.6.0.25
/opt/gcc-8.3.0/build/stage1-x86_64-pc-linux-gnu/libstdc++-v3/src/.libs/libstdc++.so
/opt/gcc-8.3.0/build/stage1-x86_64-pc-linux-gnu/libstdc++-v3/src/.libs/libstdc++.so.6
/opt/gcc-8.3.0/build/prev-x86_64-pc-linux-gnu/libstdc++-v3/src/.libs/libstdc++.so.6.0.25
/opt/gcc-8.3.0/build/prev-x86_64-pc-linux-gnu/libstdc++-v3/src/.libs/libstdc++.so
/opt/gcc-8.3.0/build/prev-x86_64-pc-linux-gnu/libstdc++-v3/src/.libs/libstdc++.so.6
/data/result/SegParser/libstdc++.so.6
/data/download_record/SegParser/libstdc++.so.6
/data/segdsegy/SegParser/libstdc++.so.6

可以看到在路徑/usr/local/lib64/libstdc++.so.6.0.25下有一個新的高版本的庫,于是將此庫復制到/usr/lib64/路徑下并重新建立軟連接:

$ cp /usr/local/lib64/libstdc++.so.6.0.25 /usr/lib64/
$ rm libstdc++.so.6
$ ln -s libstdc++.so.6.0.25 libstdc++.so.6

完成之后通過命令

strings /usr/lib64/libstdc++.so.6 | grep GLIBC

可以看到GLIBCXX_3.4.21已經存在。

問題解決。

最后編輯于
?著作權歸作者所有,轉載或內容合作請聯系作者
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發布,文章內容僅代表作者本人觀點,簡書系信息發布平臺,僅提供信息存儲服務。

推薦閱讀更多精彩內容