Golang结构化日志包log/slog的使用详解

 更新时间:2023年09月08日 08:22:01   作者:路多辛  
官方提供的用于打印日志的包是标准库中的 log 包,该包虽然被广泛使用,但是缺点也很多,所以Go 1.21新增的 log/slog 完美解决了以上问题,下面我们就来看看log/slog包的使用吧

前言

在 Go 1.21以前,官方提供的用于打印日志的包是标准库中的 log 包,该包虽然被广泛使用,但是缺点也很多,Go 社区要求改进的声音不断,主要有以下缺点:

log 包只提供了基本的日志记录功能,功能相对太过简单,缺乏很多常用功能,例如日志级别控制、自定义日志格式等,这就导致在很多应用程序中无法满足日志处理的需求。

不能自定义输出目标,log 包默认将日志输出到标准错误(stderr)。如果需要将日志输出到其他地方,例如文件、队列或日志存储系统等,就需要自己实现或者使用第三方日志包来满足这些需求。

Go 1.21新增的 log/slog 完美解决了以上问题,并且带来了很多其他很实用的特性。

log/slog 包初体验

log/slog 包提供结构化的日志记录功能,其中的日志记录包括时间、日志级别、消息和以键值对表示的各种其他属性。

log/slog 包定义了一个 Logger 结构体,这个结构体提供了几个方法(如 Logger.Info、Logger.Warn、Logger.Error等)用于打印不同级别的日志。每个 Logger 都与一个 Handler 相关联,Logger 的打印日志方法根据参数创建一条日志并传递给 Handler,由 Handler 来决定如何处理这条日志。log/slog 包提供的打印日志的函数例如 Info、Warn、Error 等,是通过调用默认 Logger 中的相关方法来实现的。

日志记录由时间、级别、消息和一组键值对组成,其中键是字符串,值可以是任何类型。看个简单的示例:

package main
import (
    "log/slog"
)
func main() {
    slog.Info("hello", "count", 3)
}

使用 slog.Info 函数创建了一条记录,包括打印时间、日志级别 Info、消息为“hello”和一个键为“count”值为 3 的键值对。运行结果如下:

2023/09/07 22:00:33 INFO hello count=3

Info 函数是通过调用默认 Logger 的 相关方法实现的,看一下 Info 函数的定义:

// Info calls Logger.Info on the default logger.
func Info(msg string, args ...any) {
    Default().log(context.Background(), LevelInfo, msg, args...)
}

可以看出调用了使用 Default 函数返回的 Logger 对象中的 log 方法实现的,Default 函数的定义如下:

func Default() *Logger { return defaultLogger.Load().(*Logger) }

defaultLogger 是 atomic.Value 类型,存储了默认的 Logger 类型,这个默认的 Logger 类型是通过 init 函数存储进去的,init 函数的定义如下:

func ç() {
    defaultLogger.Store(New(newDefaultHandler(loginternal.DefaultOutput)))
}

默认的 Logger 打印日志的函数还有 Debug、Warn 和 Error。除了这几个很方便使用的函数外,还有一个 Log 函数,可以接受一个日志级别参数。看个简单的示例:

package main
import (
    "context"
    "log/slog"
)
func main() {
    slog.Log(context.Background(), slog.LevelInfo, "hello", "count", 3)
}

运行看下效果:

2023/09/07 22:09:58 INFO hello count=3、

可以看出和 直接调用 Info 函数效果是一样的。

Logger 类型

看下 Logger 类型的定义,如下:

type Logger struct {
    handler Handler // for structured logging
}

提供了 Log、Debug、Info、Warn 和 Error 这几个打印日志的方法。

到此这篇关于Golang结构化日志包log/slog的使用详解的文章就介绍到这了,更多相关go log/slog包内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • go语言 http模型reactor示例详解

    go语言 http模型reactor示例详解

    这篇文章主要介绍了go语言 http模型reactor,接下来看一段基于reactor的示例,这里运行通过 go run main.go,本文结合示例代码给大家介绍的非常详细,需要的朋友可以参考下
    2023-01-01
  • go语言中HTTPRouter的算法演进

    go语言中HTTPRouter的算法演进

    这篇文章主要从开发中常见的应用场景 “路由管理” 为例,为大家详细介绍一下三种常用的实现方案背后的数据结构和算法,感兴趣的小伙伴可以了解一下
    2023-08-08
  • 详解Golang函数式选项(Functional Options)模式

    详解Golang函数式选项(Functional Options)模式

    什么是函数式选项模式,为什么要这么写,这个编程模式解决了什么问题呢?其实就是为了解决动态灵活的配置不同的参数的问题。下面通过本文给大家介绍Golang函数式选项(Functional Options)模式的问题,感兴趣的朋友一起看看吧
    2021-12-12
  • go mod包拉不下来的问题及解决方案

    go mod包拉不下来的问题及解决方案

    这篇文章主要介绍了go mod包拉不下来的问题及解决方案,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2023-09-09
  • 用go语言实现WebAssembly数据加密的示例讲解

    用go语言实现WebAssembly数据加密的示例讲解

    在Web开发中,有时候为了提升安全性需要对数据进行加密,由于js代码相对比较易读,直接在js中做加密安全性较低,而WebAssembly代码不如js易读,本文提供一个用go语言实现的WebAssembly数据加密示例,需要的朋友可以参考下
    2024-03-03
  • 深入理解Go语言中的闭包

    深入理解Go语言中的闭包

    Go函数是可以闭包的。闭包是一个函数值,他来自函数体外部的变量引用。 下面这篇文章通过一个demo来进行深入的介绍了Go语言中闭包的相关资料,文中介绍的非常详细,需要的朋友可以参考下。
    2017-03-03
  • Go语言基础入门应用简介及常用命令

    Go语言基础入门应用简介及常用命令

    这篇文章主要为大家介绍了Go语言基础入门应用简介及常用命令,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2021-11-11
  • Go 如何批量修改文件名

    Go 如何批量修改文件名

    这篇文章主要介绍了Go 批量修改文件名的实现方式,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2021-05-05
  • golang 四则运算计算器yacc归约手写实现

    golang 四则运算计算器yacc归约手写实现

    这篇文章主要为大家介绍了golang 四则运算 计算器 yacc 归约的手写实现,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-07-07
  • GoLang bytes.Buffer基础使用方法详解

    GoLang bytes.Buffer基础使用方法详解

    Go标准库中的bytes.Buffer(下文用Buffer表示)类似于一个FIFO的队列,它是一个流式字节缓冲区,我们可以持续向Buffer尾部写入数据,从Buffer头部读取数据。当Buffer内部空间不足以满足写入数据的大小时,会自动扩容
    2023-03-03

最新评论