linux不同環境下c/c++程式移植方法

來源:互聯網
上載者:User

這邊之前的大多數項目都用的java,而自己用的c++,等到快要上線的時候才發現線上機器的gcc和libc的版本都巨低,跟自己測試開發用的環境不相容,編譯出的c++可執行檔沒法運行。解決c++程式的移植問題費了挺大周章,如下是一個具體記錄:

1、問題描述

如上所述,線上機器與開發機環境不相容,需要做c++程式的移植。

2、表現

細節不表,總之就是程式沒法運行,找不到對應的庫。如下給出幾個跟gcc有關的錯誤提示:

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

/lib64/libc.so.6: version `GLIBC_2.7' not found

等等

3、嘗試過的方法

在開發機上使用靜態編譯可以解決大部分問題,例如thrift、cgi、redis等相關庫採用靜態編譯,線上機器就不用裝對應軟體就可以運行程式。這樣,正常的想法是把gcc相關的庫也靜態編譯進可執行檔,那麼線上機器就可以直接運行了吧,想法是好的,可惜我們嘗試了很長時間,還是以失敗告終,線上環境還是不能運行。

4、一定不要做

慘痛教訓,一定不要隨便動線上機器的libc等環境,尤其不要動核心/lib64/libc.so.6的符號連結(我當時頭腦發熱,將一些報錯的庫檔案從開發機拷貝到線上機器,然後更改線上機器庫檔案的符號連結,結果出了很大問題),或者草率升級線上機器的libc(也是教訓),這樣會造成系統直接down掉,因為核心跟使用者態的互動很多都依賴於libc庫,升級後與核心不相容,則會造成基本的ls、sudo等都沒法執行。無法進入sudo許可權,就無法恢複/lib64下被更改或升級的庫檔案,只能重啟進入急救模式,這對運行有線上服務的機器是很致命的。如果更改了libc.so.6等的軟串連或盲目升級libc等,執行基本命令時會報類似如下錯誤:

error while loading shared libraries: /lib64/libc.so.6: ELF file OS ABI invalid

更多精彩內容:http://www.bianceng.cn/Programming/cplus/

這是雖然可以通過LD_PRELOAD=/lib64/libc-2.5.so ls 載入舊的libc庫,執行一些簡單命令,但是sudo卻是怎麼都進不去的。所以一定提醒大家不要線上上機器上做這種事。

5、最終的解決辦法

1)線上機器配置:

可以在使用者目錄下,建立一個檔案夾$dir/Mylib64,為了下面表述方便,$dir表示該檔案夾的絕對路徑。檔案夾下存放開發機中/lib64/檔案夾下gcc對應的庫檔案,例如如下幾個:

2)開發機編譯選項:

在開發機makefile的g++編譯選項最後,添加如下選項用來指定動態庫的優先搜尋路徑和動態連結器:

-Wl,--rpath=$dir/lib64 -Wl,--dynamic-linker=$dir/lib64/ld-linux-x86-64.so.2

其中$dir就是1)中的絕對路徑。

這樣開發機make出的可執行檔就可以線上上機器上運行了。

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在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.