linux命令之調(diào)試工具strace的深入分析
更新時間:2013年06月03日 09:13:23 作者:
本篇文章是對調(diào)試工具strace的使用進行了詳細的分析介紹,需要的朋友參考下
參考
1《linux的strace命令(詳解).txt》 新浪電子書可下載
2man strace
一個基本上通用的 完整的用法:
strace -o output.txt -T -tt -e trace=all -p 28979
上面的含義是 跟蹤28979進程的所有系統(tǒng)調(diào)用(-e trace=all),并統(tǒng)計系統(tǒng)調(diào)用的花費時間,以及開始時間(并以可視化的時分秒格式顯示),最后將記錄結(jié)果存在output.txt文件里面。
必須記住的幾個用法
1)strace -p pid 可以跟蹤某個后臺進程
2)strace -o filename 把跟蹤結(jié)果輸出到文件
3)strace -T 記錄每個系統(tǒng)調(diào)用花費的時間,可以看看哪個系統(tǒng)調(diào)用時間長
4)strace -t (或者 -tt)記錄每個系統(tǒng)調(diào)用發(fā)生是的時間(時分秒的格式)
5)strace -s 1024 顯示系統(tǒng)調(diào)用參數(shù)時,對于字符串顯示的長度, 默認是32,如果字符串參數(shù)很長,很多信息顯示不出來。
6)strace -e trace=nanosleep 只記錄相關(guān)的系統(tǒng)調(diào)用信息。
-e trace=network // 只記錄和網(wǎng)絡(luò)api相關(guān)的系統(tǒng)調(diào)用
-e trace=file // 只記錄涉及到文件名的系統(tǒng)調(diào)用
-e trace=desc // 只記錄涉及到文件句柄的系統(tǒng)調(diào)用
還有其他的包括process,ipc,signal等。
一個經(jīng)典的,通過strace查看一個進程所有相關(guān)打開文件的排查過程,參考《linux的strace命令(詳解).txt》 新浪電子書可下載
如果開發(fā)程序沒有一個強大的工具相伴,那么開發(fā)效率會非常低,甚至遇到問題無從下手. 現(xiàn)在開始學習linux下的強大的調(diào)試工具strace,并記錄于此.
strace
1)類似于windows下的processexp.exe
可以監(jiān)控系統(tǒng)調(diào)用
2)類似于windows下的depand工具
可以檢查程序的依賴庫. 比linux下的ldd更強大.
參考:strace命令用法
點擊下載
案例:
strace幫助我解決不知日志文件被打印到哪的問題.
用strace跟蹤server
/usr/bin/strace -p pid -o out.file
然后執(zhí)行client端,然后結(jié)束strace,查看out.file 搜索write,open的系統(tǒng)調(diào)用
1《linux的strace命令(詳解).txt》 新浪電子書可下載
2man strace
一個基本上通用的 完整的用法:
strace -o output.txt -T -tt -e trace=all -p 28979
上面的含義是 跟蹤28979進程的所有系統(tǒng)調(diào)用(-e trace=all),并統(tǒng)計系統(tǒng)調(diào)用的花費時間,以及開始時間(并以可視化的時分秒格式顯示),最后將記錄結(jié)果存在output.txt文件里面。
必須記住的幾個用法
1)strace -p pid 可以跟蹤某個后臺進程
2)strace -o filename 把跟蹤結(jié)果輸出到文件
3)strace -T 記錄每個系統(tǒng)調(diào)用花費的時間,可以看看哪個系統(tǒng)調(diào)用時間長
4)strace -t (或者 -tt)記錄每個系統(tǒng)調(diào)用發(fā)生是的時間(時分秒的格式)
5)strace -s 1024 顯示系統(tǒng)調(diào)用參數(shù)時,對于字符串顯示的長度, 默認是32,如果字符串參數(shù)很長,很多信息顯示不出來。
6)strace -e trace=nanosleep 只記錄相關(guān)的系統(tǒng)調(diào)用信息。
-e trace=network // 只記錄和網(wǎng)絡(luò)api相關(guān)的系統(tǒng)調(diào)用
-e trace=file // 只記錄涉及到文件名的系統(tǒng)調(diào)用
-e trace=desc // 只記錄涉及到文件句柄的系統(tǒng)調(diào)用
還有其他的包括process,ipc,signal等。
一個經(jīng)典的,通過strace查看一個進程所有相關(guān)打開文件的排查過程,參考《linux的strace命令(詳解).txt》 新浪電子書可下載
如果開發(fā)程序沒有一個強大的工具相伴,那么開發(fā)效率會非常低,甚至遇到問題無從下手. 現(xiàn)在開始學習linux下的強大的調(diào)試工具strace,并記錄于此.
strace
1)類似于windows下的processexp.exe
可以監(jiān)控系統(tǒng)調(diào)用
2)類似于windows下的depand工具
可以檢查程序的依賴庫. 比linux下的ldd更強大.
參考:strace命令用法
點擊下載
案例:
strace幫助我解決不知日志文件被打印到哪的問題.
用strace跟蹤server
/usr/bin/strace -p pid -o out.file
然后執(zhí)行client端,然后結(jié)束strace,查看out.file 搜索write,open的系統(tǒng)調(diào)用
您可能感興趣的文章:
- pycharm遠程linux開發(fā)和調(diào)試代碼的方法
- Linux調(diào)試工具GDB使用簡易教程
- Linux應(yīng)用調(diào)試使用gdb和gdbserver命令詳解
- Linux 中Tomcat遠程調(diào)試代碼的實現(xiàn)方法
- 詳解VS2017 Linux 上.NET Core調(diào)試
- Visual Studio 2017通過SSH調(diào)試Linux上.NET Core
- Linux中使用VS Code編譯調(diào)試C++項目詳解
- 在Linux下調(diào)試Python代碼的各種方法
- 如何調(diào)試Linux shell腳本
- Linux內(nèi)核設(shè)備驅(qū)動之內(nèi)核的調(diào)試技術(shù)筆記整理
相關(guān)文章
PHP判斷用戶是否已經(jīng)登錄(跳轉(zhuǎn)到不同頁面或者執(zhí)行不同動作)
這篇文章主要介紹了PHP判斷用戶是否已經(jīng)登錄(跳轉(zhuǎn)到不同頁面或者執(zhí)行不同動作)的相關(guān)資料,非常不錯,具有參考借鑒價值,需要的朋友可以參考下2016-09-09laravel實現(xiàn)按時間日期進行分組統(tǒng)計方法示例
這篇文章主要給大家介紹了關(guān)于laravel如何實現(xiàn)按時間日期進行分組統(tǒng)計的相關(guān)資料,文中通過示例代碼介紹的非常詳細,對大家學習或者使用laravel具有一定的參考學習價值,需要的朋友們下面來一起學習學習吧2019-03-03ThinkPHP實現(xiàn)二級循環(huán)讀取的方法
這篇文章主要介紹了ThinkPHP實現(xiàn)二級循環(huán)讀取的方法,是ThinkPHP基于數(shù)組的數(shù)據(jù)庫操作中非常常見的技巧,需要的朋友可以參考下2014-11-11