登录
首页 >  Golang >  Go问答

如何使用“log/slog”记录错误

来源:stackoverflow

时间:2024-04-23 23:09:30 296浏览 收藏

哈喽!今天心血来潮给大家带来了《如何使用“log/slog”记录错误》,想必大家应该对Golang都不陌生吧,那么阅读本文就都不会很困难,以下内容主要涉及到,若是你正在学习Golang,千万别错过这篇文章~希望能帮助到你!

问题内容

官方文档展示了如何使用新的结构化日志记录包,但似乎省略了如何记录错误。

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”记录错误》文章吧,也可关注golang学习网公众号了解相关技术文章。

声明:本文转载于:stackoverflow 如有侵犯,请联系study_golang@163.com删除
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>