首頁 > 後端開發 > Golang > 如何使用'log/slog”記錄錯誤

如何使用'log/slog”記錄錯誤

PHPz
發布: 2024-02-06 11:24:03
轉載
690 人瀏覽過

如何使用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 呼叫

#
func ErrAttr(err error) slog.Attr {
    return slog.Any("error", err)
}
登入後複製

以上是如何使用'log/slog”記錄錯誤的詳細內容。更多資訊請關注PHP中文網其他相關文章!

來源:stackoverflow.com
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板