如何利用SystemTap統(tǒng)計(jì)函數(shù)執(zhí)行耗時(shí)詳解
前言
當(dāng)我們需要對(duì)應(yīng)用程序進(jìn)行系能分析時(shí),我們通??梢允褂胮erf或者火焰圖。 但是這些工具通常只能定性問(wèn)題,發(fā)現(xiàn)那些函數(shù)占用cpu較多,需要優(yōu)化。但是給不出定量的數(shù)據(jù), 比如這個(gè)函數(shù)的耗時(shí)情況,它耗時(shí)1ms還是5ms。
因此在不在代碼中加入統(tǒng)計(jì)耗時(shí)的代碼的情況,我們可以使用SystemTap來(lái)統(tǒng)計(jì)應(yīng)用程序的耗時(shí)情況。
SystemTap可以跟蹤內(nèi)核函數(shù)和用戶態(tài)進(jìn)程,當(dāng)我們跟蹤用戶態(tài)進(jìn)程時(shí),需要使用其process模塊。
查找函數(shù)符號(hào)
很多情況下,代碼在執(zhí)行時(shí),其函數(shù)符號(hào)并不一定是代碼中寫(xiě)的名稱(chēng),因此我們可以使用以下腳本打印 出應(yīng)用程序中在調(diào)用的函數(shù)符號(hào)。
probe process("/data0/app").function("*") {
println(probefunc())
}
然后執(zhí)行
stap echo.stp
其會(huì)打印出/data0/app這個(gè)程序運(yùn)行時(shí)調(diào)用到的各個(gè)函數(shù)名,此處最好填絕對(duì)路徑。我們可以從中找到 我們需要統(tǒng)計(jì)的函數(shù)名稱(chēng)。
統(tǒng)計(jì)函數(shù)耗時(shí)
我們可以使用SystemTap內(nèi)置的直方圖來(lái)展示耗時(shí)的分布。我們有兩種直方圖函數(shù)可以使用:
@hist_linear(v, start, stop, interval) # 打印start-stop區(qū)間interval間隔的直方圖 @hist_log(v) # 打印以2為底指數(shù)分布的直方圖
統(tǒng)計(jì)腳本:
global sends # 聲明全局的統(tǒng)計(jì)存儲(chǔ)容器
probe process("/data0/app").function("git.intra.xx.send").return { # function中為函數(shù)名,同時(shí)支持通配符*等,在該函數(shù)return時(shí)計(jì)算耗時(shí)
sends <<< gettimeofday_us() - @entry(gettimeofday_us()) # 以微秒精度來(lái)統(tǒng)計(jì),entry方法將一個(gè)表達(dá)式放置于函數(shù)入口處
}
probe timer.s(10) { # 每10s打印一次直方圖
print(@hist_log(sends))
}
然后執(zhí)行stap elaspe.stp即可獲得每10秒統(tǒng)計(jì)的結(jié)果,如果希望每10秒清空重新統(tǒng)計(jì)的話, 可以將打印函數(shù)修改為:
probe timer.s(10) { # 每10s打印一次直方圖
print(@hist_log(sends))
delete sends # 清空數(shù)據(jù)
}
總結(jié)
以上就是這篇文章的全部?jī)?nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作能帶來(lái)一定的幫助,如果有疑問(wèn)大家可以留言交流,謝謝大家對(duì)腳本之家的支持。
參考
相關(guān)文章
淺談linux下的一些常用函數(shù)的總結(jié)(必看篇)
下面小編就為大家?guī)?lái)一篇淺談linux下的一些常用函數(shù)的總結(jié)(必看篇)。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2016-10-10
LVS+Keepalived構(gòu)建高可用負(fù)載均衡配置方法(配置篇)
這篇文章主要介紹了LVS+Keepalived構(gòu)建高可用負(fù)載均衡配置方法,需要的朋友可以參考下2013-06-06
CentOS 8設(shè)置自動(dòng)更新的完整步驟
這篇文章主要給大家介紹了關(guān)于CentOS 8設(shè)置自動(dòng)更新的完整步驟,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家學(xué)習(xí)或者使用CentOS 8具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2019-11-11

