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

posts - 297,  comments - 15,  trackbacks - 0
1. 前言: 有的程序可以通過編譯, 但在運行時會出現Segment fault(段錯誤). 這通常都是指針錯誤引起的. 但這不像編譯錯誤一樣會提示到文件->行, 而是沒有任何信息, 使得我們的調試變得困難起來.

    2. gdb: 有一種辦法是, 我們用gdb的step, 一步一步尋找. 這放在短小的代碼中是可行的, 但要讓你step一個上萬行的代碼, 我想你會從此厭惡程序員這個名字, 而把他叫做調試員. 我們還有更好的辦法, 這就是core file.

    3. ulimit: 如果想讓系統在信號中斷造成的錯誤時產生core文件, 我們需要在shell中按如下設置: #設置core大小為無限 ulimit -c unlimited #設置文件大小為無限 ulimit unlimited 這些需要有root權限, 在ubuntu下每次重新打開中斷都需要重新輸入上面的第一條命令, 來設置core大小為無限.

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

1. 什么是Core:

Sam之前一直以為Core Dump中Core是 Linux Kernel的意思. 今天才發現在這里,Core是另一種意思:

在使用半導體作為內存的材料前,人類是利用線圈當作內存的材料(發明者為王安),線圈就叫作 core ,用線圈做的內存就叫作 core memory。如今 ,半導體工業澎勃發展,已經沒有人用 core memory 了,不過,在許多情況下, 人們還是把記憶體叫作 core 。

2. 什么是Core Dump:

我們在開發(或使用)一個程序時,最怕的就是程序莫明其妙地當掉。雖然系統沒事,但我們下次仍可能遇到相同的問題。于是這時操作系統就會把程序當掉 時的內存內容 dump 出來(現在通常是寫在一個叫 core 的 file 里面),讓 我們或是 debugger 做為參考。這個動作就叫作 core dump。

3. Core Dump時會生成何種文件:

Core Dump時,會生成諸如 core.進程號 的文件。

4. 為何有時程序Down了,卻沒生成 Core文件。

Linux下,有一些設置,標明了resources available to the shell and to processes。 可以使用#ulimit -a  來看這些設置。 (ulimit是bash built-in Command)

              -a     All current limits are reported

              -c     The maximum size of core files created

              -d     The maximum size of a process鈥檚 data segment

              -e     The maximum scheduling priority ("nice")

              -f     The maximum size of files written by the shell and its children

              -i     The maximum number of pending signals

              -l     The maximum size that m ay be locked into memory

              -m     The maximum resident set size (has no effect on Linux)

              -n     The maximum number of open file descriptors (most systems do not allow this value to be set)

              -p     The pipe size in 512-byte blocks (this may not be set)

              -q     The maximum number of bytes in POSIX message queues

              -r     The maximum real-time scheduling priority

              -s     The maximum stack size

              -t     The maximum amount of cpu time in seconds

              -u     The maximum number of processes available to a single user

              -v     The maximum amount of virtual memory available to the shell

              -x     The maximum number of file locks



 從這里可以看出,如果 -c是顯示:core file size          (blocks, -c)  如果這個值為0,則無法生成core文件。所以可以使用:
#ulimit -c 1024   或者 #ulimit -c unlimited   來使能 core文件。

如果程序出錯時生成Core 文件,則會顯示Segmentation fault (core dumped) 。

5. Core Dump的核心轉儲文件目錄和命名規則:
/proc/sys/kernel /core_uses_pid可以控制產生的core文件的文件名中是否添加pid作為擴展,如果添加則文件內容為1,否則為0

6. 如何使用Core文件:
在Linux下,使用:
#gdb -c core.pid program_name
就可以進入gdb模式。
輸入where,就可以指出是在哪一行被Down掉,哪個function內,由誰調用等等。
(gdb) where
或者輸入 bt。
(gdb) bt

7. 如何讓一個正常的程序down:
#kill -s SIGSEGV pid

8. 察看Core文件輸出在何處:
存放Coredump的目錄即進程的當前目錄,一般就是當初發出命令啟動該進程時所在的目錄。但如果是通過腳本啟動,則腳本可能會修改當前目錄,這時進程真正的當前目錄就會與當初執行腳本所在目錄不同。這時可以查看”/proc/<進程pid>/cwd“符號鏈接的目標來確定進程真正的當前目錄地址。通過系統服務啟動的進程也可通過這一方法查看。

9. 嵌入式設備下如何使用Core dump:
linux coredump配置與調試
Linux

Core Dump 配置與調試

1.core文件的生成開關和大小限制

---------------------------------

1)使用ulimit -c 命令可查看core文件的生成開關。若結果為0,則表示關閉了此功能,不會生成core文件。

2)使用ulimit -c filesize命令,可以限制core文件的大小(filesize的單位為kbyte)。若ulimit -c unlimited,則表示core文件的大小不受限制。如果生成的信息超過此大小,將會被裁剪,最終生成一個不完整的core文件。在調試此core文件的時候,gdb會提示錯誤。

2.core文件的名稱和生成路徑

----------------------------

若系統生成的core文件不帶其它任何擴展名稱,則全部命名為core。新的core文件生成將覆蓋原來的core文件 。

1)/proc/sys /kernel/core_uses_pid可以控制core文件的文件名中是否添加pid作為擴展。文件內容為1,表示添加pid作為擴展名,生成的 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文件統一生成到/corefile目錄下,產生的文件名為core-命令名-pid-時間戳

以下是參數列表:
%p - insert pid into filename 添加pid
%u - insert current uid into filename 添加當前uid
%g - insert current gid into filename 添加當前gid
%s - insert signal that caused the coredump into the filename  添加導致產生core的信號
%t - insert UNIX time that the coredump occurred into filename  添加core文件生成時的unix時間
%h - insert hostname where the coredump happened into filename  添加主機名
%e - insert coredumping executable name into filename  添加命令名

3.用gdb查看core文件:

下面我們可以在發生運行時信號引起的錯誤時發生core dump了.
發生 core dump之后,用gdb進行查看core文件的內容,以定位文件中引發core dump的行.

gdb [exec file] [core file]
如:gdb ./test test.core

在進入gdb后,用 bt命令查看backtrace以檢查發生程序運行到哪里,來定位core dump的文件->行.

4.開發板上使用core文件調試

-----------------------------

如果開發板的操作系統也是linux,core調試方法依然適用。如果開發板上不支持gdb,可將開發板的環境(頭文件、庫)、可執行文件和core文件拷貝到PC的linux下,運行相關命令即可。

注意:待調試的可執行文件,在編譯的時候需要加-g,core文件才能正常顯示出錯信息!

注意的問題:

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

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

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

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


ulimit -- 用戶資源限制命令

1、說明 :ulimit用于shell啟動進程所占用的資源.
2、類別 :shell內建命令
3、語法格式 :ulimit [-acdfHlmnpsStvw] [size]
4、參數介紹 :
-H 設置硬件資源限制.
-S 設置軟件資源限制.
-a 顯示當前所有的資源限制.
-c size:設置core文件的最大值.單位:blocks
-d size:設置數據段的最大值.單位:kbytes
-f size:設置創建文件的最大值.單位:blocks
-l size:設置在內存中鎖定進程的最大值.單位:kbytes
-m size:設置可以使用的常駐內存的最大值.單位:kbytes
-n size:設置內核可以同時打開的文件描述符的最大值.單位:n
-p size:設置管道緩沖區的最大值.單位:kbytes
-s size:設置堆棧的最大值.單位:kbytes
-t size:設置CPU使用時間的最大上限.單位:seconds
-v size:設置虛擬內存的最大值.單位:kbytes 5,簡單實例: 

5、舉例

在Linux下寫程序的時候,如果程序比較大,經常會遇到“段錯誤”(segmentationfault)這樣的問題,這主要就是由于Linux系統初始的堆棧大小(stack size)太小的緣故,一般為10M。我一般把stacksize設置成256M,這樣就沒有段錯誤了!命令為:ulimit   -s 262140

如果要系統自動記住這個配置,就編輯/etc/profile文件,在 “ulimit -S -c 0 > /dev/null 2>&1”行下,添加“ulimit   -s 262140”,保存重啟系統就可以了!

1]在RH8的環境文件/etc/profile中,我們可以看到系統是如何配置ulimit的:
#grep ulimit /etc/profile
ulimit -S -c 0 > /dev/null 2>&1
這條語句設置了對軟件資源和對core文件大小的設置

2]如果我們想要對由shell創建的文件大小作些限制,如:

#ll h
-rw-r--r-- 1 lee lee 150062 7月 22 02:39 h

#ulimit -f 100 #設置創建文件的最大塊(一塊=512字節)
#cat h>newh
File size limit exceeded

#ll newh
-rw-r--r-- 1 lee lee 51200 11月 8 11:47 newh
文件h的大小是150062字節,而我們設定的創建文件的大小是512字節x100塊=51200字節,當然系統就會根據你的設置生成了51200字節的newh文件.

3]可以像實例1]一樣,把你要設置的ulimit放在/etc/profile這個環境文件中.
用途:設置或報告用戶資源極限。
語法:ulimit [ -H ] [ -S ] [ -a ] [ -c ] [ -d ] [ -f ] [ -m ] [ -n ] [ -s ] [ -t ] [ Limit ]
描述:ulimit 命令設置或報告用戶進程資源極限,如 /etc/security/limits 文件所定義。文件包含以下缺省值極限:
fsize = 2097151
core = 2097151
cpu = -1
data = 262144
rss = 65536
stack = 65536
nofiles = 2000

當新用戶添加到系統中時,這些值被作為缺省值使用。當向系統中添加用戶時,以上值通過 mkuser 命令設置,或通過 chuser 命令更改。

極限分為軟性或硬性。通過 ulimit 命令,用戶可將軟極限更改到硬極限的最大設置值。要更改資源硬極限,必須擁有 root 用戶權限。

很多系統不包括以上一種或數種極限。 特定資源的極限在指定 Limit 參數時設定。Limit 參數的值可以是每個資源中指定單元中的數字,或者為值 unlimited。要將特定的 ulimit 設置為 unlimited,可使用詞 unlimited。

    注:在 /etc/security/limits 文件中設置缺省極限就是設置了系統寬度極限, 而不僅僅是創建用戶時用戶所需的極限。

省略 Limit 參數時,將會打印出當前資源極限。除非用戶指定 -H 標志,否則打印出軟極限。當用戶指定一個以上資源時,極限名稱和單元在值之前打印。如果未給予選項,則假定帶有了 -f 標志。

由于 ulimit 命令影響當前 shell 環境,所以它將作為 shell 常規內置命令提供。如果在獨立的命令執行環境中調用該命令,則不影響調用者環境的文件大小極限。以下示例中正是這種情況:

nohup ulimit -f 10000

env ulimit 10000

一旦通過進程減少了硬極限,若無 root 特權則無法增加,即使返回到原值也不可能。

關于用戶和系統資源極限的更多信息,請參見 AIX 5L Version 5.3 Technical Reference: BaseOperating System and Extensions Volume 1 中的 getrlimit、setrlimit 或vlimit 子例程。

標志

-a     列出所有當前資源極限。

-c     以 512 字節塊為單位,指定核心轉儲的大小。

-d     以 K 字節為單位指定數據區域的大小。

-f     使用 Limit 參數時設定文件大小極限(以塊計),或者在未指定參數時報告文件大小極限。缺省值為 -f 標志。

-H     指定設置某個給定資源的硬極限。如果用戶擁有 root 用戶權限,可以增大硬極限。任何用戶均可減少硬極限。

-m     以 K 字節為單位指定物理存儲器的大小。

-n     指定一個進程可以擁有的文件描述符的數量的極限。

-s     以 K 字節為單位指定堆棧的大小。

-S     指定為給定的資源設置軟極限。軟極限可增大到硬極限的值。如果 -H 和 -S 標志均未指定,極限適用于以上二者。

-t     指定每個進程所使用的秒數 。

退出狀態

返回以下退出值:

0     成功完成。 


from:
http://blog.chinaunix.net/uid-26707720-id-3256694.html 
posted on 2012-06-30 20:08 chatler 閱讀(4497) 評論(0)  編輯 收藏 引用 所屬分類: Linux_Coding
<2010年7月>
27282930123
45678910
11121314151617
18192021222324
25262728293031
1234567

常用鏈接

留言簿(10)

隨筆分類(307)

隨筆檔案(297)

algorithm

Books_Free_Online

C++

database

Linux

Linux shell

linux socket

misce

  • cloudward
  • 感覺這個博客還是不錯,雖然做的東西和我不大相關,覺得看看還是有好處的

network

OSS

  • Google Android
  • Android is a software stack for mobile devices that includes an operating system, middleware and key applications. This early look at the Android SDK provides the tools and APIs necessary to begin developing applications on the Android platform using the Java programming language.
  • os161 file list

overall

搜索

  •  

最新評論

閱讀排行榜

評論排行榜

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            亚洲精品乱码久久久久久久久| 欧美一区二视频在线免费观看| 99精品视频免费| 亚洲欧洲精品一区二区精品久久久 | 欧美午夜精品理论片a级大开眼界| 欧美精品久久久久a| 欧美激情精品久久久| 欧美日韩视频一区二区| 欧美激情精品久久久| 欧美xxx成人| 亚洲欧洲午夜| 亚洲综合色噜噜狠狠| 国产精品99一区| 欧美丝袜一区二区| 国产日韩欧美| 亚洲剧情一区二区| 欧美在线影院在线视频| 欧美成人精精品一区二区频| 一区二区三区四区五区精品视频| 新67194成人永久网站| 欧美大成色www永久网站婷| 国产精品福利在线观看| 樱桃成人精品视频在线播放| 亚洲视频香蕉人妖| 欧美sm视频| 亚洲无亚洲人成网站77777| 亚洲自拍偷拍麻豆| 麻豆精品视频在线| 国产精品视频精品视频| 亚洲精品免费在线| 久久激情五月婷婷| 亚洲精选一区二区| 久久欧美中文字幕| 国产日韩精品入口| 亚洲免费观看高清完整版在线观看熊 | 亚洲欧美成人在线| 欧美国产先锋| 午夜精品在线观看| 欧美日韩国产色站一区二区三区| 韩国一区二区三区美女美女秀| 一区二区三区四区国产精品| 裸体歌舞表演一区二区| 亚洲欧美国产另类| 欧美亚男人的天堂| 妖精视频成人观看www| 久久免费精品视频| 午夜伦欧美伦电影理论片| 欧美日韩一区二区三区免费看| 影音先锋成人资源站| 性伦欧美刺激片在线观看| 日韩视频免费观看| 欧美日韩99| 日韩一级不卡| 亚洲日本中文字幕| 欧美电影在线观看完整版| 在线日韩一区二区| 久久综合网hezyo| 久久精品国产99| 国产一区二区三区不卡在线观看| 国产欧美一区二区精品性色| 99国产精品久久久久久久久久| 欧美黑人国产人伦爽爽爽| 久久精品人人做人人爽电影蜜月| 国产精品一区=区| 性亚洲最疯狂xxxx高清| 亚洲视频免费在线观看| 欧美日韩一区二区视频在线| 亚洲一区二区不卡免费| 亚洲午夜电影| 国产一区二区三区在线观看精品| 午夜精品一区二区三区在线播放 | 久久综合久久美利坚合众国| 亚洲电影在线看| 亚洲人成人一区二区三区| 欧美精品免费观看二区| 99在线精品免费视频九九视| 亚洲精品一二三| 国产精品视频福利| 久久精品国亚洲| 欧美sm视频| 亚洲欧美日韩天堂| 久久综合九色综合欧美狠狠| 日韩视频中午一区| 亚洲视频在线观看网站| 国产一区二区中文字幕免费看| 久久综合亚洲社区| 欧美日韩国产综合久久| 欧美一级黄色网| 久久影院午夜论| 亚洲综合二区| 久久久久免费视频| 99在线精品观看| 欧美呦呦网站| 中日韩高清电影网| 欧美在线视屏| 夜夜狂射影院欧美极品| 欧美一区二区视频在线| 一本久久综合亚洲鲁鲁| 欧美亚洲在线| 亚洲午夜黄色| 看欧美日韩国产| 欧美亚洲视频在线观看| 欧美成人免费一级人片100| 欧美一级艳片视频免费观看| 免费成人av在线看| 午夜精品久久久久| 欧美福利网址| 久久久91精品| 欧美午夜宅男影院| 亚洲国产高清视频| 国产一区二区av| 一本大道av伊人久久综合| 在线欧美不卡| 欧美一区二区三区视频免费播放| 夜夜嗨av一区二区三区中文字幕| 欧美在线观看天堂一区二区三区| 9色porny自拍视频一区二区| 久久久噜噜噜久噜久久| 亚洲欧美成人| 亚洲天堂第二页| 亚洲精品久久久久久一区二区| 欧美在线视频a| 欧美一区二区三区视频免费| 欧美日韩色婷婷| 亚洲欧洲在线播放| 亚洲三级性片| 欧美夫妇交换俱乐部在线观看| 免费精品视频| 亚洲电影免费在线| 久久精品人人做人人爽| 欧美在线啊v一区| 国产精品久久久久久户外露出| 亚洲日韩中文字幕在线播放| 亚洲国产成人精品视频| 久久久久国产精品一区三寸| 久久精品人人| 国产三级欧美三级| 久久gogo国模啪啪人体图| 欧美伊久线香蕉线新在线| 国产精品视频免费一区| 一本一本久久a久久精品综合妖精| 99精品国产在热久久| 欧美日韩亚洲一区在线观看| 一区二区高清| 久久精品国产免费看久久精品| 国产欧美一区二区视频| 亚洲欧美综合一区| 毛片一区二区三区| 亚洲国产专区校园欧美| 欧美成人午夜激情在线| 亚洲国产婷婷香蕉久久久久久99 | 在线亚洲免费视频| 欧美精品一区在线播放| 日韩视频一区二区在线观看| 亚洲一级一区| 国产精品中文字幕欧美| 久久都是精品| 亚洲国产老妈| 亚洲私人影院在线观看| 国产精品日韩在线播放| 久久精品日韩一区二区三区| 欧美成人影音| 亚洲视频精选在线| 国产日韩欧美二区| 美女主播一区| 正在播放亚洲| 蜜桃av一区二区| 一区二区三区视频免费在线观看| 国产精品日韩精品| 久久久久久久久久久久久9999| 亚洲第一中文字幕| 亚洲自拍高清| 亚洲精美视频| 国产精品普通话对白| 欧美成年人视频| 亚洲欧美日韩国产一区| 91久久久久久久久久久久久| 欧美综合国产精品久久丁香| 影视先锋久久| 欧美日韩在线观看一区二区三区| 欧美在线一二三区| 亚洲国产91| 久久久久久精| 亚洲午夜国产一区99re久久| 亚洲国产精品第一区二区| 国产精品久久久久久av福利软件| 久久男女视频| 亚洲欧美在线高清| 欧美一级理论片| 91久久久久久久久久久久久| 国产欧美1区2区3区| 欧美日韩国产色站一区二区三区| 欧美一区国产一区| 亚洲一级在线观看| 亚洲欧洲日韩综合二区| 欧美国产亚洲视频| 免费观看成人鲁鲁鲁鲁鲁视频| 午夜精品一区二区三区在线 | 美女露胸一区二区三区| 亚洲欧美一区二区三区极速播放|