前幾天同事編譯一個新的功能,編譯的時候liblog4cxx.so 顯示GLIBCXX_3.4.21找不到的錯誤。
因為整個系統之前遷移過,從ubuntu16.04遷移到了14.04 大量的第三方都進行了重新編譯,所以這個問題我就懷疑是編譯環境的問題。進行了查找。
當前使用的是14.04 ,當前的機子里面尋找libstdc++.so ,當前的版本是libstdc++.so.6.0.19
使用 strings libstdc++.so.6.0.19 |grep GLIBCXX_ 進行查找,果然不包含3.4.21
$ strings libstdc++.so.6.0.19 |grep GLIBCXX
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
GLIBCXX_DEBUG_MESSAGE_LENGTH
而又有問題的那個庫進行了查找,包含了3.4.21 版本
strings liblog4cxx.so.10.0.0 |grep GLIBCXX_
GLIBCXX_3.4.20
GLIBCXX_3.4.11
GLIBCXX_3.4.21
GLIBCXX_3.4
GLIBCXX_3.4.9
所以分析應該是有人將16.04編譯出來的庫直接放到了14.04的系統中。
將liblog4cxx.so.10.0.0 的源碼找出來,在14.04上重新編譯一下。然后查看結果,果然沒有3.4.21了,
strings liblog4cxx.so.10.0.0 |grep GLIBCXX_
GLIBCXX_3.4.11
GLIBCXX_3.4
GLIBCXX_3.4.9
將新編譯的庫放入14.04系統中,編譯問題果然解決了。