ホームページ > Java > &#&チュートリアル > btrace が本番環境の障害を特定する方法の例

btrace が本番環境の障害を特定する方法の例

黄舟
リリース: 2017-03-06 10:21:10
オリジナル
1331 人が閲覧しました

この記事では、主に btrace の運用上の障害を特定する方法の例をサンプルコードを通じて詳しく紹介します。必要な方は以下を参照してください。

前書き

プログラムの実行詳細についてさらに知る必要があることがよくありますが、開発中にプログラム内のすべての実行詳細をログに出力することは不可能です。通常、現時点でできることは次のとおりです。コードを修正して再デプロイして観察するという方法がありますが、この方法はオンライン アプリケーションにはあまり適していません。一方、他の外部パッケージを参照するなど、変更が難しいコードに遭遇した場合は非常に面倒です。は、コードを変更したり、アプリケーションを再起動したりせずに、プログラムの実行の詳細を動的に表示できるツールです。次の記事では、btrace の本番環境の障害を特定する方法を紹介しています。必要な場合は、それを参照してください。

現象

一部のリクエストはデータアクセス層経由で非常に遅く、処理スレッドがブロックされ、監視から例外を検出できません。

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();
 }
 }
}
ログイン後にコピー

10秒以上実行されるSQLとスタック情報を判定します。

スクリプト DBProxyTrace.Java をコンパイルし、スクリプトに問題がないことを確認します。

./bin/btracec -cp build/ java/DBProxyTrace.java
ログイン後にコピー

スクリプトの実行 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 ドライバーがシリアル要求の応答を保証するために最下層にロックを追加するためです。チャネルは遅いステートメントがブロックされているため、ロールバックはブロックされています。

概要

上記は、btrace による運用上の障害を特定する方法の例の内容です。さらに関連するコンテンツについては、PHP 中国語 Web サイト (www.php.cn) に注目してください。


関連ラベル:
ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
最新の問題
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート