Java 기능에서는 로깅 및 추적을 사용하여 실행 중에 발생하는 이벤트를 기록하여 빠르고 정확하게 문제를 식별하고 해결할 수 있습니다. 로깅은 java.util.logging 패키지의 Logger 클래스를 사용하고, 추적은 이벤트 수준을 기록하고 함수 실행 흐름을 추적하여 함수 실행을 완전히 이해하는 데 사용할 수 있는 Stackdriver Trace API를 사용합니다.
로깅 및 추적을 사용하여 Java 기능 디버깅을 돕는 방법
Java 기능을 개발할 때 로깅 및 추적은 프로덕션 환경에 존재할 수 있는 다양한 문제를 해결하는 데 매우 유용한 도구입니다. 이러한 기술을 사용하면 함수 실행 중에 발생하는 이벤트를 기록하고 문제를 빠르고 정확하게 식별하고 해결하는 데 도움이 됩니다.
Logging
Logging은 함수 실행 중에 발생하는 중요한 이벤트를 텍스트 파일이나 기타 저장 장치에 기록하는 프로세스입니다. 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("错误消息")); } }
위 코드는 로깅을 사용하여 정보, 경고, 오류 등 다양한 이벤트 수준을 기록하는 방법을 보여줍니다.
Tracing
Tracing은 로깅과 유사하지만 함수 실행 중에 발생하는 이벤트 흐름을 기록하는 데 더 중점을 둡니다. 이는 기능의 흐름을 이해하고 성능 병목 현상을 식별하는 데 유용합니다. 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 중국어 웹사이트의 기타 관련 기사를 참조하세요!