一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

服務器之家:專注于服務器技術及軟件下載分享
分類導航

PHP教程|ASP.NET教程|Java教程|ASP教程|編程技術|正則表達式|C/C++|IOS|C#|Swift|Android|VB|R語言|JavaScript|易語言|vb.net|

服務器之家 - 編程語言 - Java教程 - btrace定位生產故障的方法示例

btrace定位生產故障的方法示例

2020-08-09 22:43java教程網 Java教程

這篇文章主要介紹了btrace定位生產故障的方法示例,文中通過示例代碼介紹的很詳細,相信對大家具有一定的參考價值,需要的朋友們下面來一起看看吧。

前言

很多時候我們需要知道更多的程序的運行細節,但又不可能在開發的時候就把程序中所有的運行細節都打印到日志上,通常這個時候能采取的就是修改代碼,重新部署,然后再觀察,但這種方法對于online應用來說不是很好,另外一方面如果碰到不好改的代碼,例如引用的其他的外部的包什么的,就很麻煩了,BTrace就是一個可以在不改代碼、不重啟應用的情況下,動態的查看程序運行細節的工具,下面這篇文章就介紹了btrace定位生產故障的方法,需要的朋友們可以參考借鑒。

現象

某些請求通過數據訪問層很慢并導致處理線程阻塞,從監控中未能檢查到異常。

編寫btrace腳本

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
@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();
 }
 }
}

判斷執行大于10秒的sql和堆棧信息。

編譯腳本DBProxyTrace.Java,確認腳本沒有問題。

?
1
./bin/btracec -cp build/ java/DBProxyTrace.java

執行腳本DBProxyTrace.class

?
1
./bin/btrace -cp build/ 17342 DBProxyTrace.class

信息

?
1
2
3
4
5
6
7
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堆棧

?
1
2
3
4
"$_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塞了。

總結

以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作能帶來一定的幫助,如果有疑問大家可以留言交流。

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 日韩一卡2卡3卡新区网站 | 猛男深夜狂cao小男生 | 国产高清专区 | 日本嫩交 | 国产日韩欧美 | 午夜精品在线视频 | 久久99精品国产自在自线 | 国产精品四虎在线观看免费 | 91精品国产色综合久久不卡蜜 | 91精品国产综合久久精品 | 欧美精品一区二区三区免费观看 | 99ri在线视频网 | 男人在女人下面狂躁 | 成全动漫视频在线观看 | 亚洲精品乱码久久久久久蜜桃欧美 | 久久91精品国产91久 | 2012年免费中文视频 | 99精品热视频 | 亚洲haose在线观看 | 欧美大b| 嫩草精品 | 2018久久精品热在线观看 | 欧洲男同直粗无套播放视频 | chinese特色video | 天堂激情网 | 好大好硬好深好爽想要小雪 | 黑人巨大精品战中国美女 | 国产精品日本一区二区不卡视频 | 1024免费观看完整版在线播放 | 亚洲第一男人网站 | 国产精品一久久香蕉产线看 | 国产精品 色 | 麻豆性视频 | 亚洲黄色免费在线观看 | 美国一级大黄大色毛片 | 亚洲国产精品ⅴa在线观看 亚洲国产高清一区二区三区 | 国产人成77777视频网站 | 四虎影业 | 99热资源 | a级亚洲片精品久久久久久久 | 扒开斗罗美女了的胸罩和内裤漫画 |