linux命令之調試工具strace的深入分析

來源:互聯網
上載者:User

參考
1《linux的strace命令(詳解).txt》 新浪電子書可下載
2man strace
一個基本上通用的 完整的用法:
strace -o output.txt -T -tt -e trace=all -p 28979
上面的含義是 跟蹤28979進程的所有系統調用(-e trace=all),並統計系統調用的花費時間,以及開始時間(並以可視化的時分秒格式顯示),最後將記錄結果存在output.txt檔案裡面。
必須記住的幾個用法
1)strace -p pid 可以跟蹤某個後台進程
2)strace -o filename 把跟蹤結果輸出到檔案
3)strace -T 記錄每個系統調用花費的時間,可以看看哪個系統調用時間長
4)strace -t (或者 -tt)記錄每個系統調用發生是的時間(時分秒的格式)
5)strace -s 1024 顯示系統調用參數時,對於字串顯示的長度, 預設是32,如果字串參數很長,很多資訊顯示不出來。
6)strace -e trace=nanosleep 只記錄相關的系統調用資訊。
-e trace=network // 只記錄和網路api相關的系統調用
-e trace=file // 只記錄涉及到檔案名稱的系統調用
-e trace=desc // 只記錄涉及到檔案控制代碼的系統調用
還有其他的包括process,ipc,signal等。
一個經典的,通過strace查看一個進程所有相關開啟檔案的排查過程,參考《linux的strace命令(詳解).txt》 新浪電子書可下載
如果開發程式沒有一個強大的工具相伴,那麼開發效率會非常低,甚至遇到問題無從下手. 現在開始學習linux下的強大的調試工具strace,並記錄於此.
strace
1)類似於windows下的processexp.exe
可以監控系統調用
2)類似於windows下的depand工具
可以檢查程式的依賴庫. 比linux下的ldd更強大.
參考:strace命令用法
點擊下載
案例:
strace協助我解決不知記錄檔被列印到哪的問題.
用strace跟蹤server
/usr/bin/strace -p pid -o out.file
然後執行client端,然後結束strace,查看out.file 搜尋write,open的系統調用
相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.