掃二維碼與項(xiàng)目經(jīng)理溝通
我們?cè)谖⑿派?4小時(shí)期待你的聲音
解答本文疑問(wèn)/技術(shù)咨詢/運(yùn)營(yíng)咨詢/技術(shù)建議/互聯(lián)網(wǎng)交流
Linux被廣泛用于服務(wù)器系統(tǒng),很多線上服務(wù)在上線前要做壓力測(cè)試,對(duì)發(fā)現(xiàn)的性能問(wèn)題要進(jìn)一步排查和開發(fā)優(yōu)化性能。

創(chuàng)新互聯(lián)堅(jiān)持“要么做到,要么別承諾”的工作理念,服務(wù)領(lǐng)域包括:成都做網(wǎng)站、網(wǎng)站建設(shè)、企業(yè)官網(wǎng)、英文網(wǎng)站、手機(jī)端網(wǎng)站、網(wǎng)站推廣等服務(wù),滿足客戶于互聯(lián)網(wǎng)時(shí)代的新羅網(wǎng)站設(shè)計(jì)、移動(dòng)媒體設(shè)計(jì)的需求,幫助企業(yè)找到有效的互聯(lián)網(wǎng)解決方案。努力成為您成熟可靠的網(wǎng)絡(luò)建設(shè)合作伙伴!
比如通過(guò) top 、iostat 等命令找到了引起資源異常的進(jìn)程后,就要進(jìn)一步對(duì)該進(jìn)程/線程的內(nèi)存占用、文件系統(tǒng)IO系統(tǒng)調(diào)用次數(shù)、Socket和網(wǎng)絡(luò)通訊阻塞問(wèn)題等做跟蹤分析。由于此時(shí)往往更希望接近真實(shí)場(chǎng)景的運(yùn)行方式,所以除了采用代碼斷點(diǎn)調(diào)試的方式外,最保真、最快速跟蹤到實(shí)際環(huán)境問(wèn)題根源的就是用Linux系統(tǒng)自帶的strace軟件啟動(dòng)問(wèn)題軟件,獲得直接的數(shù)據(jù)實(shí)現(xiàn),故障分析、性能分析。
這是一款Linux下瑞士軍刀級(jí)別的工具,開發(fā)者、運(yùn)維人員如果不熟悉,那么非常有必要繼續(xù)往下看。學(xué)會(huì)后可以事半功倍地解決工作中遇到的各類軟件開發(fā)和軟件運(yùn)維問(wèn)題。
統(tǒng)計(jì)異常系統(tǒng)調(diào)用耗時(shí)、系統(tǒng)調(diào)用次數(shù)過(guò)多的情況:使用strace跟蹤vs code 這個(gè)代碼編輯器的運(yùn)行(軟件文件路徑為 /usr/bin/code )為例:
sudo strace -o strace.log -T -S time -k -O1ns -C -v /usr/bin/code --no-sandbox --user-data-dir /root/data除了輸出啟動(dòng)過(guò)程從哪些目錄,加載了什么動(dòng)態(tài)庫(kù),用到了什么系統(tǒng)調(diào)用(系統(tǒng)接口函數(shù)),函數(shù)調(diào)用返回值,入?yún)⒅档榷加写蛴?。由于上面參?shù)中使用了-C也就是要求打印匯總報(bào)告,所以在最后會(huì)列出vs code啟動(dòng)過(guò)程中涉及到多少系統(tǒng)調(diào)用、每個(gè)系統(tǒng)調(diào)用的時(shí)間百分比、時(shí)間總計(jì)、調(diào)用次數(shù)、錯(cuò)誤次數(shù)、系統(tǒng)調(diào)用的函數(shù)名。
并在最后一行列出匯總值。
假如我們的業(yè)務(wù)代碼中有個(gè)功能存在bug,過(guò)多調(diào)用了系統(tǒng)調(diào)用(次數(shù)維度),或者傳入的參數(shù)不科學(xué)導(dǎo)致系統(tǒng)調(diào)用執(zhí)行時(shí)間過(guò)長(zhǎng)(時(shí)間維度),那么,通過(guò)strace 的報(bào)告我們可以馬上觀察到線索。再翻看 strace 的 -o strace.log 逐個(gè)系統(tǒng)調(diào)用跟蹤的日志記錄文件,就可以具體排查以下多方面:
最后總結(jié)下:
sudo strace -o strace.log -T -S time -k -O1ns -C -v /usr/bin/code --no-sandbox --user-data-dir /root/data這個(gè)示例命令中參數(shù)的意思:

我們?cè)谖⑿派?4小時(shí)期待你的聲音
解答本文疑問(wèn)/技術(shù)咨詢/運(yùn)營(yíng)咨詢/技術(shù)建議/互聯(lián)網(wǎng)交流