'log/slog'를 사용하여 오류를 기록하는 방법

PHPz
풀어 주다: 2024-02-06 11:24:03
앞으로
628명이 탐색했습니다.

log/slog를 사용하여 오류를 기록하는 방법

질문 내용

공식 문서에는 새로운 구조화된 로깅 패키지를 사용하는 방법이 나와 있지만 오류를 기록하는 방법은 생략된 것 같습니다.

https://pkg.go.dev/log/slog

package main

import (
    "fmt"
    "log/slog"
    "os"
)

func demoFunction() error {
    return fmt.Errorf("oh no: %v", 123)
}

func main() {
    logger := slog.New(slog.NewJSONHandler(os.Stdout, nil))
    slog.SetDefault(logger)

    slog.Info("info demo", "count", 3)
    slog.Warn("warn demo", slog.String("somekey", "somevalue"))
    slog.Error("error demo", slog.Int("someintkey", 123))
    err := demoFunction()
    if err != nil {
        // Here I'm logging the error as a string, but I presume there is a better way
        // possibly that will log stack trace info as well.
        slog.Error("the demo function got an error.", slog.String("error", err.Error()))
    }
}
로그인 후 복사

정답


누군가 제안을 해서 닫았네요. 나는 그것이 불필요한 구문 설탕이 된다고 생각합니다.

누군가slog.Any 통화

를 마무리하기로 결정한 것 같습니다. 으아악

위 내용은 'log/slog'를 사용하여 오류를 기록하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:stackoverflow.com
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿