系統(tǒng)層面的性能微調(diào)工具_(dá)第1頁
系統(tǒng)層面的性能微調(diào)工具_(dá)第2頁
系統(tǒng)層面的性能微調(diào)工具_(dá)第3頁
系統(tǒng)層面的性能微調(diào)工具_(dá)第4頁
系統(tǒng)層面的性能微調(diào)工具_(dá)第5頁
已閱讀5頁,還剩11頁未讀 繼續(xù)免費(fèi)閱讀

下載本文檔

版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)

文檔簡介

1、Oprofile系統(tǒng)層面的性能微調(diào)工具褚霸核心系統(tǒng)數(shù)據(jù)庫組2010/11/15用途及關(guān)鍵特性 非侵入式,無需重新編譯系統(tǒng). 整個(gè)系統(tǒng)層面的Profile, All code is profiled. 利用硬件計(jì)數(shù)器. 低overhead. OProfile is a system-wide profiler for Linux systems, capable of profiling all running code at low overhead.Oprofile系統(tǒng)工作流圖安裝(RHEL5U4)首先需要安裝內(nèi)核符號(hào)信息rpm -i kernel-debu

2、ginfo-common-2.6.18-164.el5.x86_64.rpmrpm -i kernel-debuginfo-2.6.18-164.el5.x86_64.rpm安裝好的vmlinux在這里: /usr/lib/debug/lib/modules/2.6.18-164.el5/vmlinuxOprofile發(fā)行版內(nèi)置的,無需安裝,最新版本0.9.6文檔: man oprofile官方網(wǎng)站: http:/ CPU上可以觀測的事件列表:opcontrol -list-events 設(shè)置事件:opcontrol -setup -event=name:count:unitmask:kern

3、el:user -event=xxxx 常用的事件有以下幾種: CPU_CLK_UNHALTED: CPU執(zhí)行時(shí)間 LLC_MISSES: 末級(jí)Cache miss DTLB_MISSES: 數(shù)據(jù)TLB miss準(zhǔn)備我們的程序我們的程序,包括內(nèi)核驅(qū)動(dòng)都需要有符號(hào)信息: 應(yīng)用程序這樣編譯:gcc -g foo.c . 查看內(nèi)核的導(dǎo)出的符號(hào)信息:cat /proc/kallsyms 初始化Oprofile# 加載oprofile內(nèi)核模塊opcontrol -init #我們對(duì)內(nèi)核的取樣沒興趣opcontrol -setup -no-vmlinux#我們需要內(nèi)核的取樣 opcontrol -setu

4、p -vmlinux=/usr/lib/debug/lib/modules/2.6.18-164.el5/vmlinux采樣數(shù)據(jù)#在開始收集采樣數(shù)據(jù)前回顧下我們的設(shè)置opcontrol -status#清除上一次采樣到的數(shù)據(jù)opcontrol -reset #啟動(dòng)oprofiled守護(hù)程序,從內(nèi)核中拉出采樣數(shù)據(jù) opcontrol -start #運(yùn)行我們的程序./foo #中途收集采樣數(shù)據(jù)opcontrol -dump#關(guān)閉守護(hù)程序, 同時(shí)準(zhǔn)備好采樣的數(shù)據(jù)opcontrol -shutdown采樣報(bào)告 #系統(tǒng)級(jí)別的opreport -long-filenames#模塊級(jí)別的opreport

5、image:foo -l#源碼級(jí)別的opannotate image:foo -s最常用的命令opcontrol -init opcontrol -setup -no-vmlinux opcontrol -status opcontrol -startopcontrol -dumpopcontrol -shutdownopcontrol -reset opreport -long-filenames opreport image:filename -l opannotate image:filename -s 實(shí)例演示-代碼(ex1.c)#include const char* find_st

6、r(const char* s, int l) const char* e = s+l; while(s e) if(*s = ) return s; s+; int main(int argc, char* argv) char*s = argv1; int i, l; if(argc =1) return -1; l=strlen(s); for(i = 0; i 100000000; i+) find_str(s, l); return 0; 一步步來看下實(shí)際效果opcontrol -setup -e CPU_CLK_UNHALTED:6000:0:0:1opcontrol -statusopcontrol -reset & opcontrol -start time ./ex1 helloworld opcontrol -shutdownopannotate image:/home/w

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
  • 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 人人文庫網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
  • 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。

評(píng)論

0/150

提交評(píng)論