ホームページ >バックエンド開発 >Golang >「log/slog」を使用してエラーを記録する方法

「log/slog」を使用してエラーを記録する方法

PHPz
PHPz転載
2024-02-06 11:24:03687ブラウズ

「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 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事はstackoverflow.comで複製されています。侵害がある場合は、admin@php.cn までご連絡ください。