• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>

            Thronds

            一問你會什么 二問你做出過什么 三問你為了什么

              C++博客 :: 首頁 :: 新隨筆 :: 聯系 :: 聚合  :: 管理 ::
              36 隨筆 :: 0 文章 :: 56 評論 :: 0 Trackbacks
                這是我在做計算實驗程序時碰到的一個小問題。場景是這樣的,自己的機器上運行的是ubuntu8.10,gcc 4.2,也經常apt-get update。用于運行計算任務的是學院的一臺IBM cluster 1350服務器,上面的系統是 rhel3。在ubuntu下編輯編譯好程序,將執行文件放入服務器上運行。出問題之前,在程序中沒有#include <stdlib.h>,ubuntu下的程序在rhel3上運行良好。加了#include <stdlib.h>后,在rhel3中運行出現問題 /lib/tls/libc.so.6: version `GLIBC_2.4' not found 。問題是小問題,但也學了不少知識,看下面分析過程。
                分析一,stdlib.h包文件包含在那個包中?glibc是GNU c函數庫,這提供給我們編寫c代碼的大部分庫函數,這個stdlib.h也在其中咯。但是rhel3上也是有glibc的,yum -qa|grep glibc,是glibc-2.3.2-95.30,低于2.4,但為什么出現了版本依賴問題呢?已知信息:編輯和編譯的平臺是ubuntu,運行的平臺是redhat,系統兼容問題;ubuntu的包都被我時常更新,redhat 則是e as3,里面的包比較舊。按照這樣的思路,在redhat上安裝了glibc_2.4的包后,程序如期能夠運行。還有東西可學,繼續...
               分析二,既然開始認為不同linux之間,可能出現問題,那么就找了另外一臺redhat系統,redhat as4, glibc.2.3.4,高于服務器的glibc-2.3.2。將程序在redhat as4上編譯成執行文件,拷貝到redhat as3上運行,也可以正常運行。哎?這個為什么就行了!可見不同linux系統之間的編程環境差別性有待進一步學習。
                分析三,既然是包依賴的問題,那么看看是否可以避免這個包依賴。在編譯時采用的是動態連接的方式,如果采用靜態連接的編譯,會不會就好了。加入/usr/lib/libc.a,得到了比原來大許多的執行文件,拷入redhat as3上,依然出現同樣問題;加入-static /usr/lib/libc.a,得到的執行文件還要更大一些,放入redhat as3上執行,反饋是 “FATAL: kernel too old   Segmentation fault ” 。靜態連接的含義是什么?靜態連接編譯出的執行文件在執行的時候,調用包含在頭文件里的庫函數的順序規則是什么?Linux中靜態鏈接與動態鏈接涉及到Linux共享函數庫。共享函數庫是為了供開發方便和減少冗余,里面包含了常用的函數。動態鏈接得到的執行文件在執行的時候,會動態調用庫中的函數,它的執行文件中沒有包含庫函數的實體,因而執行文件相應就會小些;而靜態鏈接則是將要調用的庫中函數鏈接到執行文件當中,這樣執行文件中就有一份庫函數拷貝了,在執行的時候就不用去調用共享庫中的函數而是直接使用這份拷貝,但文件相應會大了許多。依照此分析,我用-static(這個參數禁止使用了共享庫,所以不用關心共享庫而直接執行)編譯出的文件,在redhat as3上執行的反饋是kernel too old,說明了在執行我的執行文件時,kernel版本和glibc版本之間還出現了沖突。(PS:在google "fatal:kernel too old"得到的大多數文檔中,是問在編譯內核時出現了這個錯誤,回答是和glibc相關)那么內核和glibc的關系有是什么呢?[6]

            關于glibc的文件解釋
            [1]http://blog.csdn.net/My_emdebed/archive/2007/04/22/1574746.aspx
            靜態鏈接libc的一個例子
            [2]http://www.9php.com/FAQ/cxsjl/c/2007/04/704307080637.html
            進一步了解靜態鏈接和動態鏈接
            [3]http://cmdblock.blog.51cto.com/415170/86802
            gcc筆記
            [4]http://www.cublog.cn/u/13991/showart.php?id=96714
            [5]http://www.bloghome.cn/posts/10410
            GCC,glibc,kernel的要點//Linux發布程序要注意版本的軟件包
            [6]http://www.linux-cn.com/html/linux/network/20080818/57908.html
            posted on 2009-03-28 23:01 thronds 閱讀(5199) 評論(3)  編輯 收藏 引用 所屬分類: C++技術Linux/Unix高級技術

            評論

            # re: ubuntu8.10下編譯好的程序 到redhat服務器上碰到的問題: glibc_2.4 not found 2009-03-31 13:57 阿福1
            問題最終解決沒有?
            你是如何解決的?
            期待你后續的文章。  回復  更多評論
              

            # re: ubuntu8.10下編譯好的程序 到redhat服務器上碰到的問題: glibc_2.4 not found 2009-04-01 11:34 thronds
            后續又分析了一下,請參考文中補充的。問題早已解決,但不是根本之策,只是更新了glibc庫而已。對這個問題的深入理解,還請各位指教。@阿福1
              回復  更多評論
              

            # re: ubuntu8.10下編譯好的程序 到redhat服務器上碰到的問題: glibc_2.4 not found 2009-04-01 13:11 crazyc0de
            你靜態鏈接到的glibc是根據2.6的內核編譯的,glibc在編譯的時候可以指定內核支持--enable-kernel=2.4.0。實際上glibc只依賴于binutils,gcc和linux header api。而你所用的glibc多半是直接從網上下的二進制包,建議自己編譯glibc和gcc等重要軟件。  回復  更多評論
              

            久久久久亚洲精品天堂久久久久久| 色婷婷狠狠久久综合五月| 亚洲精品无码成人片久久| 久久精品国产精品亚洲精品| 久久国产高潮流白浆免费观看| 九九久久99综合一区二区| 久久久久久国产a免费观看不卡| 欧美精品丝袜久久久中文字幕| 国产亚洲精久久久久久无码77777| 69久久夜色精品国产69| 性做久久久久久久久浪潮| 精品无码久久久久国产| 亚洲精品无码专区久久同性男| 蜜臀av性久久久久蜜臀aⅴ麻豆| 狠狠精品久久久无码中文字幕| 亚洲国产另类久久久精品小说| 国内精品伊人久久久久影院对白 | 久久久久人妻一区精品色| 中文字幕一区二区三区久久网站| 久久天天躁狠狠躁夜夜2020一| 91精品久久久久久无码| 久久精品无码专区免费青青| 天堂无码久久综合东京热| 99热热久久这里只有精品68| 麻豆成人久久精品二区三区免费 | 亚洲国产成人久久笫一页| 99久久精品毛片免费播放| 精品久久久久久中文字幕大豆网| 99久久精品免费看国产| 久久亚洲AV成人无码电影| 久久久久精品国产亚洲AV无码| 欧美亚洲国产精品久久| 精品久久久久久久国产潘金莲| 久久久久97国产精华液好用吗| 国产精品欧美久久久久无广告| 91精品国产高清久久久久久国产嫩草| 国产成人无码久久久精品一| 精品国产一区二区三区久久| 国产精品久久久久久久久| 91精品国产91热久久久久福利| 狠狠精品干练久久久无码中文字幕|