工作5年胸梆,我總結(jié)了這些分析Linux進(jìn)程的方法计维,全都告訴你。

文章每周持續(xù)更新吃谣,各位的「三連」是對(duì)我最大的肯定乞封。可以微信搜索公眾號(hào)「 后端技術(shù)學(xué)堂 」第一時(shí)間閱讀(一般比博客早更新一到兩篇)

操作系統(tǒng)「進(jìn)程」是學(xué)計(jì)算機(jī)都要接觸的基本概念岗憋,拋開那些純理論的操作系統(tǒng)底層實(shí)現(xiàn)肃晚,在Linux下做軟件開發(fā)這么多年,每次程序運(yùn)行出現(xiàn)問題澜驮,都要一步一步分析進(jìn)程各種狀態(tài)陷揪,去排查問題出在哪里,這次lemon帶你在Linux環(huán)境下實(shí)操杂穷,一步步探究揭開「Linux進(jìn)程」的那些秘密悍缠。

何為進(jìn)程

首先我們說下「程序」的概念,程序是一些保存在磁盤上的指令的有序集合耐量,是靜態(tài)的飞蚓。進(jìn)程是程序執(zhí)行的過程,包括了動(dòng)態(tài)創(chuàng)建廊蜒、調(diào)度和消亡的整個(gè)過程趴拧,它是程序資源管理的最小單位。

線程是操作操作系統(tǒng)能夠進(jìn)行運(yùn)算調(diào)度的最小單位山叮。大部分情況下著榴,它被包含在進(jìn)程之中,是進(jìn)程中的實(shí)際運(yùn)作單位屁倔,一個(gè)進(jìn)程內(nèi)可以包含多個(gè)線程脑又,是資源調(diào)度的最小單位。「引用維基百科」

多線程程序模型

探究進(jìn)程第一步问麸,你在嗎往衷?還好嗎?

ps

report a snapshot of the current processes. 列出當(dāng)前系統(tǒng)進(jìn)程的快照严卖。

找到進(jìn)程PID ( Process IDentity )席舍,pid唯一標(biāo)識(shí)一個(gè)進(jìn)程。用ps這個(gè)命令哮笆,這個(gè)命令大家應(yīng)該都知道吧来颤,對(duì)于小白用戶,首先他不是Photoshop疟呐。

ps

給大家簡單介紹一下脚曾,一般用法是ps -ef列出系統(tǒng)內(nèi)經(jīng)常信息东且,通常都會(huì)帶管道grep出自己感興趣的進(jìn)程启具,像這樣ps -ef|grep intresting第一列PID代表進(jìn)程號(hào),PPID(parent process ID)代表父進(jìn)程號(hào)珊泳。

ps輸出實(shí)例

探究進(jìn)程第二步鲁冯,讓我看看你都交了哪些朋友(系統(tǒng)調(diào)用 & 信號(hào))

strace

strace - trace system calls and signals 跟蹤進(jìn)程內(nèi)部的系統(tǒng)調(diào)用和信號(hào)

什么是「系統(tǒng)調(diào)用」?系統(tǒng)調(diào)用(system call)色查,指運(yùn)行在「用戶態(tài)」的程序向操作系統(tǒng)「內(nèi)核態(tài)」請(qǐng)求需要更高權(quán)限運(yùn)行的服務(wù)薯演,系統(tǒng)調(diào)用提供用戶程序與操作系統(tǒng)之間的接口。

strace后面跟著啟動(dòng)一個(gè)進(jìn)程秧了,可以跟蹤啟動(dòng)后進(jìn)程的系統(tǒng)調(diào)用和信號(hào)跨扮,這個(gè)命令可以看到進(jìn)程執(zhí)行時(shí)候都調(diào)用了哪些系統(tǒng)調(diào)用,通過指定不同的選項(xiàng)可以輸出系統(tǒng)調(diào)用發(fā)生的時(shí)間验毡,精度可以精確到微秒衡创,甚至還可以統(tǒng)計(jì)分析系統(tǒng)「調(diào)用的耗時(shí)」,這在排查進(jìn)程假死問題的時(shí)候很有用晶通,能幫你發(fā)現(xiàn)進(jìn)程卡在哪個(gè)系統(tǒng)調(diào)用上璃氢。已經(jīng)在運(yùn)行的進(jìn)程也可以指定-p參數(shù)加pidgdb attach那樣附著上去跟蹤。

strace

strace1

探究進(jìn)程第三步狮辽,讓我看看你帶的小弟們(線程)一也。

pstack

print a stack trace of a running process 打印出運(yùn)行中程序的堆棧信息。

執(zhí)行命令pstack pid 你能看到當(dāng)前線程運(yùn)行中的堆棧信息喉脖,其中的pid可用之前的ps命令獲得椰苟,pstack可以看到進(jìn)程內(nèi)啟動(dòng)的線程號(hào),每個(gè)進(jìn)程內(nèi)線程的「堆検鬟矗」內(nèi)容也能看到舆蝴。

pstack

看到上面打印出的LWP了嗎,這里是個(gè)知識(shí)點(diǎn), LPW是指Light-weight process 輕量級(jí)線程须误。引申知識(shí):

  1. Linux中沒有真正的線程
  2. Linux中沒有的線程Thread是由進(jìn)程來模擬實(shí)現(xiàn)的所以稱作:輕量級(jí)進(jìn)程
  3. 進(jìn)程是「資源管理」的最小單元挨稿,線程是「資源調(diào)度」的最小單元(這里不考慮協(xié)程)

探究進(jìn)程第四步,讓小弟們(線程)出來排個(gè)隊(duì)吧京痢。

pstree

pstree - display a tree of processes pstree按樹形結(jié)構(gòu)打印運(yùn)行中進(jìn)程結(jié)構(gòu)信息

可以直觀的查看進(jìn)程和它啟動(dòng)的線程的關(guān)系奶甘,并能顯示進(jìn)程標(biāo)識(shí)。

pstree

探究進(jìn)程第五步祭椰,是死(進(jìn)程崩潰)是活(進(jìn)程運(yùn)行中)我都要知道你的秘密(堆棧幀 & 上下文)臭家。

gdb

gdb是GNU開發(fā)的gcc套件中Linux下程序調(diào)試工具,你可以查看程序的堆棧方淤、設(shè)置斷點(diǎn)钉赁、打印程序運(yùn)行時(shí)信息,甚至還能調(diào)試多線程程序携茂,功能十分強(qiáng)大你踩。

在這里把gdb當(dāng)成一個(gè)命令來講有點(diǎn)大材小用,要詳細(xì)說gdb的話讳苦,完全可以撐起一篇文章的篇幅带膜,這里長話短說,有機(jī)會(huì)再開一篇文章詳細(xì)介紹下它鸳谜。

使用

要用gdb調(diào)試C/C++程序首先編譯的時(shí)候要加-g選項(xiàng)膝藕,g++ -g test.cpp -o test這樣生成的程序就可以用gdb來調(diào)試?yán)病?/p>

  1. 可以直接用gdb啟動(dòng)程序調(diào)試,命令:gdb prog
  2. 用gdb附著到一個(gè)已經(jīng)啟動(dòng)的進(jìn)程上調(diào)試也可以咐扭。命令:gdb prog pid
  3. 程序崩潰之后參數(shù)corefile也可以用gdb調(diào)試芭挽,看看程序死掉之前留了什么遺言(堆棧信息)給你。命令:gdb prog corefile蝗肪,這里有一點(diǎn)需要注意袜爪,有些Linux系統(tǒng)默認(rèn)程序崩潰不生成corefile,這時(shí)你需要ulimit -c unlimited這樣就能生成corefile了穗慕。
    gdb調(diào)試

探究進(jìn)程第六步饿敲,關(guān)于你的所有,我都想知道逛绵。

更近一步

通過/proc/pid文件了解進(jìn)程的運(yùn)行時(shí)信息和統(tǒng)計(jì)信息怀各。/proc系統(tǒng)是一個(gè)偽文件系統(tǒng),它只存在內(nèi)存當(dāng)中术浪,而不占用外存空間瓢对,以文件系統(tǒng)的方式為內(nèi)核與進(jìn)程提供通信的接口。進(jìn)入系統(tǒng)/proc目錄:

proc目錄

/proc目錄下有很多以數(shù)字命名的目錄胰苏,每個(gè)數(shù)字代表進(jìn)程號(hào)PID它們是進(jìn)程目錄硕蛹。系統(tǒng)中當(dāng)前運(yùn)行的每一個(gè)進(jìn)程在/proc下都對(duì)應(yīng)一個(gè)以進(jìn)程號(hào)為目錄名的目錄/proc/pid,它們是讀取進(jìn)程信息的接口,我們可以進(jìn)到這個(gè)文件里面法焰,了解進(jìn)程的運(yùn)行時(shí)信息和統(tǒng)計(jì)信息秧荆。

高頻使用

/proc/pid目錄下的有一些重要文件,挑幾個(gè)使用頻率高的講一講埃仪。
/proc/pid/environ 包含了進(jìn)程的可用環(huán)境變量的列表 乙濒。程序出問題了如果不確定環(huán)境變量是否設(shè)置生效,可以cat這個(gè)文件出來查看確認(rèn)一下卵蛉。

/proc/pid/fd/ 這個(gè)目錄包含了進(jìn)程打開的每一個(gè)文件的鏈接颁股。從這里可以查看進(jìn)程打開的文件描述符信息,包括標(biāo)準(zhǔn)輸入傻丝、輸出甘有、錯(cuò)誤流,進(jìn)程打開的socket連接文件描述符也能看到葡缰,lsof命令也有類似的作用亏掀。

/proc/pid/stat包含了進(jìn)程的所有狀態(tài)信息,進(jìn)程號(hào)运准、父進(jìn)程號(hào)幌氮、 線程組號(hào)缭受、 該任務(wù)在用戶態(tài)運(yùn)行的時(shí)間 胁澳、 該任務(wù)在用內(nèi)核態(tài)運(yùn)行的時(shí)間、 虛擬地址空間的代碼段米者、 阻塞信號(hào)的位圖等等信息應(yīng)有盡有韭畸。

其他統(tǒng)計(jì)

/proc/pid/cmdline 包含了用于開始進(jìn)程的命令
/proc/pid/cwd包含了當(dāng)前進(jìn)程工作目錄的一個(gè)鏈接
/proc/pid/exe包含了正在進(jìn)程中運(yùn)行的程序鏈接
/proc/pid/mem包含了進(jìn)程在內(nèi)存中的內(nèi)容
/proc/pid/statm包含了進(jìn)程的內(nèi)存使用信息

好了,一頓操作下來蔓搞,你對(duì)進(jìn)程和它背后的秘密你已經(jīng)非常了解了胰丁,下次我們的好朋友「進(jìn)程」如果遇到了什么問題(崩潰coredump、假死喂分、阻塞锦庸、系統(tǒng)調(diào)用超時(shí)、文件描述符異常)蒲祈,你應(yīng)該知道如何幫它處理了吧甘萧!我們來總結(jié)一下:

  • ps查看進(jìn)程id,看看進(jìn)程還在不在以及進(jìn)程狀態(tài)
  • 如果在的話strace梆掸、psstack看下進(jìn)程當(dāng)前信息扬卷,是不卡死在哪個(gè)位置,對(duì)比各幀最后調(diào)用信息找到異常點(diǎn)
  • 如果進(jìn)程不再了酸钦,如果有corefile文件怪得,直接上gdb查看corefile信息
  • 其他疑難雜癥懷疑進(jìn)程狀態(tài)信息的時(shí)候,看看/proc/pid下面的進(jìn)程狀態(tài)信息,可能會(huì)給你啟發(fā)徒恋。
  • 最后蚕断,如果以上都不行,閉目祈禱吧入挣!
image

寫在最后

今天的分享希望對(duì)你有幫助基括,祝大家寫的服務(wù)永不宕機(jī),從不coredump财岔,讓上面教你的操作吃灰去吧风皿。


永不宕機(jī)

最后,感謝各位的閱讀匠璧。文章的目的是分享對(duì)知識(shí)的理解桐款,技術(shù)類文章我都會(huì)反復(fù)求證以求最大程度保證準(zhǔn)確性,若文中出現(xiàn)明顯紕漏也歡迎指出夷恍,我們一起在探討中學(xué)習(xí)魔眨。

可以微信搜索公眾號(hào)「 后端技術(shù)學(xué)堂 」回復(fù)「資料」有我給你準(zhǔn)備的各種編程學(xué)習(xí)資料。文章每周持續(xù)更新酿雪,我們下期見遏暴!

reference

https://man.linuxde.net/gdb

https://blog.csdn.net/dan15188387481/article/details/49450491

https://blog.csdn.net/m0_37925202/article/details/78759408

https://blog.csdn.net/enweitech/article/details/53391567

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市指黎,隨后出現(xiàn)的幾起案子朋凉,更是在濱河造成了極大的恐慌,老刑警劉巖醋安,帶你破解...
    沈念sama閱讀 222,464評(píng)論 6 517
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件杂彭,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡吓揪,警方通過查閱死者的電腦和手機(jī)亲怠,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 95,033評(píng)論 3 399
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來柠辞,“玉大人团秽,你說我怎么就攤上這事“仁祝” “怎么了习勤?”我有些...
    開封第一講書人閱讀 169,078評(píng)論 0 362
  • 文/不壞的土叔 我叫張陵,是天一觀的道長放棒。 經(jīng)常有香客問我姻报,道長,這世上最難降的妖魔是什么间螟? 我笑而不...
    開封第一講書人閱讀 59,979評(píng)論 1 299
  • 正文 為了忘掉前任吴旋,我火速辦了婚禮损肛,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘荣瑟。我一直安慰自己治拿,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 69,001評(píng)論 6 398
  • 文/花漫 我一把揭開白布笆焰。 她就那樣靜靜地躺著劫谅,像睡著了一般。 火紅的嫁衣襯著肌膚如雪嚷掠。 梳的紋絲不亂的頭發(fā)上捏检,一...
    開封第一講書人閱讀 52,584評(píng)論 1 312
  • 那天,我揣著相機(jī)與錄音不皆,去河邊找鬼贯城。 笑死,一個(gè)胖子當(dāng)著我的面吹牛霹娄,可吹牛的內(nèi)容都是我干的能犯。 我是一名探鬼主播,決...
    沈念sama閱讀 41,085評(píng)論 3 422
  • 文/蒼蘭香墨 我猛地睜開眼犬耻,長吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼踩晶!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起枕磁,我...
    開封第一講書人閱讀 40,023評(píng)論 0 277
  • 序言:老撾萬榮一對(duì)情侶失蹤渡蜻,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后透典,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體晴楔,經(jīng)...
    沈念sama閱讀 46,555評(píng)論 1 319
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 38,626評(píng)論 3 342
  • 正文 我和宋清朗相戀三年峭咒,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片纪岁。...
    茶點(diǎn)故事閱讀 40,769評(píng)論 1 353
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡凑队,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出幔翰,到底是詐尸還是另有隱情漩氨,我是刑警寧澤,帶...
    沈念sama閱讀 36,439評(píng)論 5 351
  • 正文 年R本政府宣布遗增,位于F島的核電站叫惊,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏做修。R本人自食惡果不足惜霍狰,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 42,115評(píng)論 3 335
  • 文/蒙蒙 一抡草、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧蔗坯,春花似錦康震、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,601評(píng)論 0 25
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至绘梦,卻和暖如春橘忱,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背卸奉。 一陣腳步聲響...
    開封第一講書人閱讀 33,702評(píng)論 1 274
  • 我被黑心中介騙來泰國打工鹦付, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人择卦。 一個(gè)月前我還...
    沈念sama閱讀 49,191評(píng)論 3 378
  • 正文 我出身青樓敲长,卻偏偏與公主長得像,于是被迫代替她去往敵國和親秉继。 傳聞我的和親對(duì)象是個(gè)殘疾皇子祈噪,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,781評(píng)論 2 361

推薦閱讀更多精彩內(nèi)容