溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

怎么利用SystemTap統(tǒng)計(jì)函數(shù)執(zhí)行耗時(shí)

發(fā)布時(shí)間:2021-02-20 16:33:16 來(lái)源:億速云 閱讀:396 作者:小新 欄目:服務(wù)器

小編給大家分享一下怎么利用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)并不一定是代碼中寫的名稱,因此我們可以使用以下腳本打印 出應(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ù)名稱。

統(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ù)
}

以上是“怎么利用SystemTap統(tǒng)計(jì)函數(shù)執(zhí)行耗時(shí)”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對(duì)大家有所幫助,如果還想學(xué)習(xí)更多知識(shí),歡迎關(guān)注億速云行業(yè)資訊頻道!

向AI問(wèn)一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI