当前位置: > > > > 如何使用“log/slog”记录错误
如何使用“log/slog”记录错误
来源:stackoverflow
2024-04-23 23:09:30
0浏览
收藏
哈喽!今天心血来潮给大家带来了《如何使用“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()))
}
}
正确答案
有人并关闭了它。我认为它最终会成为不必要的语法糖。
看来已经决定包装 调用
func ErrAttr(err error) slog.Attr {
return slog.Any("error", err)
}
文中关于的知识介绍,希望对你的学习有所帮助!若是受益匪浅,那就动动鼠标收藏这篇《如何使用“log/slog”记录错误》文章吧,也可关注米云公众号了解相关技术文章。
