Java 関数では、ロギングとトレースを使用することで、実行中に発生したイベントを記録し、問題を迅速かつ正確に特定して解決することができます。ロギングには java.util.logging パッケージの Logger クラスが使用され、追跡には Stackdriver Trace API が使用されます。これを使用すると、イベント レベルを記録し、関数実行フローを追跡して関数の実行を完全に理解できます。
ロギングとトレースを使用して Java 関数のデバッグを支援する方法
Java 関数を開発する場合、問題を解決するには運用環境 ロギングとトレースは、存在する可能性のあるさまざまな問題に対して非常に役立つツールです。これらの手法を使用すると、関数の実行中に発生するイベントを記録でき、問題を迅速かつ正確に特定して修正するのに役立ちます。
ロギング
ロギングは、関数の実行中に発生する重要なイベントをテキスト ファイルまたは他のストレージ デバイスに記録するプロセスです。 java.util.logging
パッケージの Logger
クラスを使用してロギングを実装できます。
import java.util.logging.Logger; public class MyFunction { private static final Logger logger = Logger.getLogger(MyFunction.class.getName()); public static void main(String[] args) { // 记录一条提示信息 logger.info("函数开始执行"); // 记录一条警告信息 logger.warning("检测到潜在问题"); // 记录一条错误信息 logger.error("发生异常", new Exception("错误消息")); } }
上記のコードは、ログを使用して情報、警告、エラーなどのさまざまなイベント レベルを記録する方法を示しています。
トレース
トレースはログ記録に似ていますが、関数の実行中に発生するイベントのフローを記録することに重点を置いています。これは、関数の流れを理解し、パフォーマンスのボトルネックを特定するのに役立ちます。 Stackdriver Trace API を使用してトレースを実装できます。
import com.google.cloud.functions.CloudEventsFunction; import com.google.cloud.trace.v2.Span; import com.google.cloud.trace.v2.SpanContext; import com.google.cloud.trace.v2.SpanId; import com.google.cloud.trace.v2.TraceContext; import com.google.cloud.trace.v2.TraceId; import com.google.cloud.trace.v2.TraceRecord; import com.google.cloud.trace.v2.TraceServiceClient; import com.google.cloud.trace.v2.TraceSpan; public class MyTracedFunction implements CloudEventsFunction { private TraceServiceClient traceServiceClient; // 构造函数用于创建TraceServiceClient public MyTracedFunction() { // 在函数中使用TraceServiceClient时,需要进行认证 // 参考:https://googleapis.dev/java/google-cloud-trace/latest/index.html traceServiceClient = TraceServiceClient.create(); } @Override public void accept(CloudEvent event) { // 获取事件中的追踪信息 SpanContext spanContext = TraceContext .newBuilder() .setTraceId(TraceId.of(event.getId())) .build(); // 创建一个新的跟踪范围 Span span = Span .newBuilder() .setSpanId(SpanId.create()) .setName("my-function") .setSpanContext(spanContext) .build(); try (TraceRecord traceRecord = TraceRecord.newBuilder().addSpans(span).build()) { // 在传递控制权给被追踪函数之前将跟踪记录发送到Stackdriver traceServiceClient.createTraceRecord(traceRecord); // 在这里将跟踪范围传递给要追踪的函数 } finally { // 发送最后一个跟踪范围的结束时间 traceServiceClient.createTraceRecord(TraceRecord.getDefaultInstance()); } } }
上の例では、関数をトレースし、TraceServiceClient を使用してトレース情報を Stackdriver に送信します。 Cloud Logging コンソールを通じて追跡情報を表示できます。
ログとトレースを組み合わせて使用すると、関数の実行を完全に理解し、問題を簡単に特定して解決できます。これは、実稼働環境で Java 機能の保守とトラブルシューティングを行うために重要です。
以上がロギングとトレースを使用して Java 関数のデバッグを支援するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。