• <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>

            S.l.e!ep.¢%

            像打了激速一樣,以四倍的速度運(yùn)轉(zhuǎn),開心的工作
            簡單、開放、平等的公司文化;尊重個性、自由與個人價值;
            posts - 1098, comments - 335, trackbacks - 0, articles - 1
              C++博客 :: 首頁 :: 新隨筆 :: 聯(lián)系 :: 聚合  :: 管理

            Linux Core Dump

            Posted on 2010-04-09 10:24 S.l.e!ep.¢% 閱讀(760) 評論(0)  編輯 收藏 引用 所屬分類: Unix

            Linux Core Dump 配置與調(diào)試


            1.core文件的生成開關(guān)和大小限制
            ---------------------------------
            1)使用ulimit -c命令可查看core文件的生成開關(guān)。若結(jié)果為0,則表示關(guān)閉了此功能,不會生成core文件。
            2) 使用ulimit -cfilesize命令,可以限制core文件的大小(filesize的單位為kbyte)。若ulimit -cunlimited,則表示core文件的大小不受限制。如果生成的信息超過此大小,將會被裁剪,最終生成一個不完整的core文件。在調(diào)試此 core文件的時候,gdb會提示錯誤。


            2.core文件的名稱和生成路徑
            ----------------------------
            若系統(tǒng)生成的core文件不帶其它任何擴(kuò)展名稱,則全部命名為core。新的core文件生成將覆蓋原來的core文件。
            1)/proc/sys/kernel/core_uses_pid可以控制core文件的文件名中是否添加pid作為擴(kuò)展。文件內(nèi)容為1,表示添加pid作為擴(kuò)展名,生成的core文件格式為core.xxxx;為0則表示生成的core文件同一命名為core。
            可通過以下命令修改此文件:
            echo "1" > /proc/sys/kernel/core_uses_pid
            2)proc/sys/kernel/core_pattern可以控制core文件保存位置和文件名格式。
            可通過以下命令修改此文件:
            echo "/corefile/core-%e-%p-%t" > core_pattern,可以將core文件統(tǒng)一生成到/corefile目錄下,產(chǎn)生的文件名為core-命令名-pid-時間戳
            以下是參數(shù)列表:
            ??? %p - insert pid into filename 添加pid
            ??? %u - insert current uid into filename 添加當(dāng)前uid
            ??? %g - insert current gid into filename 添加當(dāng)前gid
            ??? %s - insert signal that caused the coredump into the filename 添加導(dǎo)致產(chǎn)生core的信號
            ??? %t - insert UNIX time that the coredump occurred into filename 添加core文件生成時的unix時間
            ??? %h - insert hostname where the coredump happened into filename 添加主機(jī)名
            ??? %e - insert coredumping executable name into filename 添加命令名

            3.用gdb查看core文件:
            下面我們可以在發(fā)生運(yùn)行時信號引起的錯誤時發(fā)生core dump了.
            發(fā)生core dump之后, 用gdb進(jìn)行查看core文件的內(nèi)容, 以定位文件中引發(fā)core dump的行.
            gdb [exec file] [core file]
            如:
            gdb ./test test.core
            在進(jìn)入gdb后, 用bt命令查看backtrace以檢查發(fā)生程序運(yùn)行到哪里, 來定位core dump的文件->行.


            4.開發(fā)板上使用core文件調(diào)試
            -----------------------------
            如果開發(fā)板的操作系統(tǒng)也是linux,core調(diào)試方法依然適用。如果開發(fā)板上不支持gdb,可將開發(fā)板的環(huán)境(頭文件、庫)、可執(zhí)行文件和core文件拷貝到PC的linux下,運(yùn)行相關(guān)命令即可。
            注意:待調(diào)試的可執(zhí)行文件,在編譯的時候需要加-g,core文件才能正常顯示出錯信息!

            ?

            注意的問題:

            在Linux下要保證程序崩潰時生成Coredump要注意這些問題:

              一、要保證存放Coredump的目錄存在且進(jìn)程對該目 錄有寫權(quán)限。存放Coredump的目錄即進(jìn)程的當(dāng)前目錄,一般就是當(dāng)初發(fā)出命令啟動該進(jìn)程時所在的目錄。但如果是通過腳本啟動,則腳本可能會修改當(dāng)前目 錄,這時進(jìn)程真正的當(dāng)前目錄就會與當(dāng)初執(zhí)行腳本所在目錄不同。這時可以查看”/proc/<進(jìn)程pid>/cwd“符號鏈接的目標(biāo)來確定進(jìn)程 真正的當(dāng)前目錄地址。通過系統(tǒng)服務(wù)啟動的進(jìn)程也可通過這一方法查看。

              二、若程序調(diào)用了seteuid()/setegid()改變 了進(jìn)程的有效用戶或組,則在默認(rèn)情況下系統(tǒng)不會為這些進(jìn)程生成Coredump。很多服務(wù)程序都會調(diào)用seteuid(),如MySQL,不論你用什么用 戶運(yùn)行mysqld_safe啟動MySQL,mysqld進(jìn)行的有效用戶始終是msyql用戶。如果你當(dāng)初是以用戶A運(yùn)行了某個程序,但在ps里看到的 這個程序的用戶卻是B的話,那么這些進(jìn)程就是調(diào)用了seteuid了。為了能夠讓這些進(jìn)程生成core dump,需要將/proc/sys/fs /suid_dumpable文件的內(nèi)容改為1(一般默認(rèn)是0)。

              三、這個一般都知道,就是要設(shè)置足夠大的Core文件大小限制 了。程序崩潰時生成的Core文件大小即為程序運(yùn)行時占用的內(nèi)存大小。但程序崩潰時的行為不可按平常時的行為來估計,比如緩沖區(qū)溢出等錯誤可能導(dǎo)致堆棧被 破壞,因此經(jīng)常會出現(xiàn)某個變量的值被修改成亂七八糟的,然后程序用這個大小去申請內(nèi)存就可能導(dǎo)致程序比平常時多占用很多內(nèi)存。因此無論程序正常運(yùn)行時占用 的內(nèi)存多么少,要保證生成Core文件還是將大小限制設(shè)為unlimited為好。


            from?
            ??http://easwy.com/blog/archives/customize-filename-of-core-dump/
            ??http://www.unix-center.net/bbs/viewthread.php?tid=12164

            久久精品亚洲中文字幕无码麻豆 | 精品久久久久久国产潘金莲| 久久久久久久精品妇女99| 精品伊人久久大线蕉色首页| 国产精品久久久久久一区二区三区| 久久亚洲国产午夜精品理论片| 日本亚洲色大成网站WWW久久| 久久久噜噜噜久久熟女AA片| 久久久噜噜噜久久中文字幕色伊伊| 欧美日韩精品久久久免费观看| 99久久精品国产高清一区二区| 久久综合色区| 久久99精品国产一区二区三区| 久久婷婷国产剧情内射白浆| 国产精品激情综合久久 | 久久久WWW成人| 国产美女久久久| 久久婷婷成人综合色综合| 久久精品国产精品亚洲人人 | 久久久久亚洲爆乳少妇无| 99精品久久精品| 亚洲色大成网站www久久九| 久久精品亚洲欧美日韩久久| 99999久久久久久亚洲| 精品熟女少妇AV免费久久| 久久婷婷色综合一区二区| 伊人久久大香线焦综合四虎| 91精品国产综合久久精品| 久久久无码精品亚洲日韩按摩 | 亚洲国产视频久久| 久久国产精品一区| 91精品国产色综久久| 日本精品久久久久中文字幕| 99久久久精品| 99久久精品费精品国产一区二区| 亚洲国产精品无码久久一线| 99久久精品国产一区二区| 中文字幕无码免费久久| 久久精品成人欧美大片| 久久婷婷五月综合成人D啪| 99久久国产宗和精品1上映|