前言

我們擁有10多年網頁設計和網站建設經驗,從網站策劃到網站制作,我們的網頁設計師為您提供的解決方案。為企業(yè)提供網站建設、做網站、微信開發(fā)、小程序制作、成都手機網站制作、H5響應式網站、等業(yè)務。無論您有什么樣的網站設計或者設計方案要求,我們都將富于創(chuàng)造性的提供專業(yè)設計服務并滿足您的需求。
很多時候我們需要知道更多的程序的運行細節(jié),但又不可能在開發(fā)的時候就把程序中所有的運行細節(jié)都打印到日志上,通常這個時候能采取的就是修改代碼,重新部署,然后再觀察,但這種方法對于online應用來說不是很好,另外一方面如果碰到不好改的代碼,例如引用的其他的外部的包什么的,就很麻煩了,BTrace就是一個可以在不改代碼、不重啟應用的情況下,動態(tài)的查看程序運行細節(jié)的工具,下面這篇文章就介紹了btrace定位生產故障的方法,需要的朋友們可以參考借鑒。
現象
某些請求通過數據訪問層很慢并導致處理線程阻塞,從監(jiān)控中未能檢查到異常。
編寫btrace腳本
@BTrace
public class DBProxyTrace {
@OnMethod(clazz = "xxx.xxx.QueryHandler", method = "query",
location = @Location(Kind.RETURN))
public static void trace2(String sql, @Duration long duration) {
if (duration/1000000 > 10 * 1000) {
com.sun.btrace.BTraceUtils.println(duration/1000000 + "ms");
com.sun.btrace.BTraceUtils.println("this task executes more than 10s. the sql is : "
+ sql);
com.sun.btrace.BTraceUtils.println("jstack is : ");
com.sun.btrace.BTraceUtils.jstack();
}
}
}判斷執(zhí)行大于10秒的sql和堆棧信息。
編譯腳本DBProxyTrace.Java,確認腳本沒有問題。
./bin/btracec -cp build/ java/DBProxyTrace.java
執(zhí)行腳本DBProxyTrace.class
./bin/btrace -cp build/ 17342 DBProxyTrace.class
信息
10468ms this task executes more than 10s. the sql is : rollback jstack is : xxx.QueryHandler.query(QueryHandler.java:106) xxx.net.AbstractConnection.onReadData(AbstractConnection.java:245) xxx.net.NIOReactor$RW.run(NIOReactor.java:77) java.lang.Thread.run(Thread.java:745)
定位
阻塞在事務回滾。
使用jstack進一步定位。
打印JVM堆棧
"$_NIOREACTOR-7-RW" prio=10 tid=0x00007f069856f000 nid=0xde1 waiting for monitor entry [0x00007f0677011000] java.lang.Thread.State: BLOCKED (on object monitor) at Oracle.jdbc.driver.PhysicalConnection.rollback(PhysicalConnection.java:1167) - waiting to lock <0x000000068086fbc0> (a oracle.jdbc.driver.T4CConnection)
結論
阻塞在了oracle驅動rollback動作,這里其實是因為oracle驅動為了保證串行請求響應而在底層加了鎖,而這個通道被慢語句塞住了,所以rollback塞了。
總結
以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作能帶來一定的幫助,如果有疑問大家可以留言交流。
網頁名稱:btrace定位生產故障的方法示例
網站路徑:http://www.chinadenli.net/article12/pgdsgc.html
成都網站建設公司_創(chuàng)新互聯,為您提供用戶體驗、自適應網站、網站建設、動態(tài)網站、網站導航、品牌網站制作
聲明:本網站發(fā)布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創(chuàng)新互聯