青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

Thronds

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

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

關(guān)于glibc的文件解釋
[1]http://blog.csdn.net/My_emdebed/archive/2007/04/22/1574746.aspx
靜態(tài)鏈接libc的一個例子
[2]http://www.9php.com/FAQ/cxsjl/c/2007/04/704307080637.html
進(jìn)一步了解靜態(tài)鏈接和動態(tài)鏈接
[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發(fā)布程序要注意版本的軟件包
[6]http://www.linux-cn.com/html/linux/network/20080818/57908.html
posted on 2009-03-28 23:01 thronds 閱讀(5237) 評論(3)  編輯 收藏 引用 所屬分類: C++技術(shù)Linux/Unix高級技術(shù)

評論

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

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

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

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            亚洲男人天堂2024| 在线亚洲欧美专区二区| 欧美一区二视频| 午夜一级久久| 激情文学一区| 欧美国产一区二区在线观看| 欧美成人高清视频| 正在播放日韩| 欧美一级在线视频| 亚洲国产一区二区a毛片| 亚洲国产专区校园欧美| 欧美日韩免费观看中文| 亚洲欧洲av一区二区| 欧美一区二区视频97| 亚洲东热激情| 亚洲一区二区三区色| 亚洲一区视频在线| 亚洲电影免费在线 | 日韩一级黄色大片| 夜久久久久久| 国产专区综合网| 亚洲欧洲日本专区| 国产一区导航| 91久久在线视频| 国产日韩欧美在线视频观看| 欧美激情视频给我| 国产九九精品视频| 亚洲国产日韩欧美在线图片| 国产精品一级二级三级| 欧美激情一区二区三区全黄| 国产精品人成在线观看免费| 欧美成年人视频网站| 国产女人水真多18毛片18精品视频| 免费日韩av片| 国产日产欧美精品| 一区二区三区四区五区精品| 激情亚洲成人| 午夜精品区一区二区三| 一区二区三区四区五区视频| 另类尿喷潮videofree| 欧美一区二区三区视频免费播放| 欧美精品一区二区三区四区| 免费在线日韩av| 国产欧美一区二区精品秋霞影院| 亚洲免费观看高清完整版在线观看熊 | 精品成人在线观看| 亚洲一区欧美| 中文国产一区| 欧美成黄导航| 欧美aaaaaaaa牛牛影院| 国产一区二区三区视频在线观看| 艳女tv在线观看国产一区| 亚洲精品乱码久久久久久日本蜜臀| 久久国产一区| 久久夜色精品| 黑人巨大精品欧美黑白配亚洲 | 欧美激情视频网站| 在线观看国产日韩| 久久久久久999| 久久综合色影院| 伊人色综合久久天天| 欧美在线免费观看视频| 久久青草欧美一区二区三区| 国内揄拍国内精品少妇国语| 欧美在线免费一级片| 欧美综合国产| 国产视频亚洲精品| 欧美一区二区精美| 裸体素人女欧美日韩| 一区精品在线播放| 久久免费视频网| 你懂的成人av| 亚洲伦理在线观看| 一本色道久久88亚洲综合88| 在线亚洲观看| 国产伦精品一区二区三区免费| 中文国产一区| 久久久99精品免费观看不卡| 激情久久一区| 蜜桃久久精品乱码一区二区| 亚洲日本中文字幕区| 亚洲网站啪啪| 国产欧美一区二区三区在线看蜜臀| 欧美一区二区三区四区高清 | 亚洲欧美日韩国产成人精品影院| 欧美午夜不卡视频| 欧美亚洲三区| 亚洲第一福利在线观看| 亚洲精品视频在线播放| 国产精品久久福利| 久久精品免费观看| 亚洲破处大片| 久久www免费人成看片高清 | 欧美日韩亚洲一区二区三区在线 | 久久在线免费观看| 亚洲日本欧美| 久久视频精品在线| 日韩视频一区二区三区在线播放免费观看 | 午夜精品av| 亚洲电影一级黄| 亚洲欧美在线一区二区| 亚洲国产合集| 国产麻豆综合| 欧美精品九九| 欧美一区二区三区免费视| 最新国产成人在线观看| 久久激情综合网| 一区二区三区欧美视频| 精品1区2区| 国产精品久久久免费| 久久综合久久久久88| 亚洲性视频网址| 亚洲国产日韩欧美| 蜜臀av性久久久久蜜臀aⅴ| 欧美一区=区| 夜夜夜精品看看| 在线成人av网站| 国产欧美一区二区三区在线老狼| 欧美日韩精品在线视频| 狼人社综合社区| 午夜在线视频一区二区区别| 一区二区福利| 亚洲高清av在线| 免费欧美在线视频| 久久久精品久久久久| 亚洲免费视频成人| 一区二区国产精品| 日韩天堂在线观看| 亚洲欧洲视频在线| 在线播放不卡| 激情亚洲成人| 狠狠干成人综合网| 国产一区二区按摩在线观看| 国产精品久久久久久一区二区三区| 欧美精品电影| 欧美国产成人精品| 欧美激情一区二区久久久| 免费在线看成人av| 狂野欧美激情性xxxx欧美| 免费成人黄色| 另类天堂视频在线观看| 久久久久亚洲综合| 久久国产视频网| 久久久91精品国产一区二区三区| 久久精品国产精品| 久久精品视频免费播放| 久久国产88| 久久久久亚洲综合| 男人插女人欧美| 欧美大成色www永久网站婷| 老巨人导航500精品| 亚洲国产成人一区| 9l国产精品久久久久麻豆| 日韩一级裸体免费视频| 亚洲视频中文字幕| 午夜激情一区| 久久综合一区二区三区| 欧美极品aⅴ影院| 欧美午夜电影完整版| 国产午夜精品理论片a级探花| 国产主播喷水一区二区| 1024欧美极品| 在线午夜精品自拍| 久久激情中文| 亚洲欧洲精品一区二区| 一区二区三区国产| 久久精品道一区二区三区| 另类综合日韩欧美亚洲| 欧美成人a∨高清免费观看| 欧美激情1区| 国产女主播一区二区三区| 激情综合网址| 一本大道久久a久久精品综合| 欧美亚洲自偷自偷| 老司机久久99久久精品播放免费| 亚洲国产另类精品专区| 亚洲一区二区精品在线观看| 久久免费视频网站| 国产精品国产自产拍高清av王其| 精品动漫3d一区二区三区免费| 亚洲欧洲在线免费| 西瓜成人精品人成网站| 欧美国产精品日韩| 中国成人黄色视屏| 久久视频在线看| 国产精品国内视频| 91久久国产综合久久91精品网站| 亚洲欧美另类中文字幕| 欧美福利视频一区| 亚洲一区二区三区免费观看 | 欧美成人免费在线| 国产精品qvod| 亚洲精品久久久久中文字幕欢迎你| 性久久久久久久久久久久| 亚洲欧洲日本专区| 久久精品欧美日韩| 国产精品日韩| 在线中文字幕不卡| 欧美黄色精品| 久久精品女人天堂|