程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> 網頁編程 >> PHP編程 >> 關於PHP編程 >> linux命令之調試工具strace的深入分析

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

編輯:關於PHP編程

參考
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的系統調用

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved