go 中的日志级别-ag捕鱼王app官网

go 中的日志级别

作者:迹忆客 最近更新:2023/04/27 浏览次数:

本篇文章介绍如何在 golang 中创建和使用日志级别。


go 中的日志级别

golang提供了一个日志包,名为log,是一个简单的日志包。 这个包不提供分级日志; 如果我们想要分级日志记录,我们必须手动添加前缀,如 debug、info 和 warn。

即使 golang 的日志包没有分级日志的功能,但它仍然提供了手动实现日志分级的基本工具。 让我们尝试一个 golang 日志包的基本示例:

package main
import "log"
func main() {
    log.println("hello, this is jiyik.com!")
}

上面的代码将记录给定的内容并打印出来。 查看输出:

2023/03/10 23:00:00 hello, this is jiyik.com!

但是日志级别呢? 如上所述,我们可以创建自定义日志级别和自定义记录器。

我们可以使用方法 log.new(),它接受以下三个参数来创建一个新的记录器:

out - out 用于实现 io.writer 接口写入日志数据。 prefix - 前缀是将添加到每行开头的字符串。 flag - 该标志用于定义记录器将使用哪些属性。 现在通常使用七个日志级别:

log 级别 描述
trace 最低级别
debug 第二级
info 第三级
warn 第四级
error 第五级
fatal 第六级
panic 最高级别

让我们尝试一个基于信息、警告、调试和错误级别创建自定义日志记录级别的示例:

package main
import (
    "fmt"
    "io/ioutil"
    "log"
    "os"
)
var (
    warning_level *log.logger
    info_level    *log.logger
    debug_level   *log.logger
    error_level   *log.logger
)
func init() {
    file, err := os.openfile("demo_logs.txt", os.o_append|os.o_create|os.o_wronly, 0666)
    if err != nil {
        log.fatal(err)
    }
    info_level = log.new(file, "info: ", log.ldate|log.ltime|log.lshortfile)
    warning_level = log.new(file, "warning: ", log.ldate|log.ltime|log.lshortfile)
    debug_level = log.new(file, "debug: ", log.ldate|log.ltime|log.lshortfile)
    error_level = log.new(file, "error: ", log.ldate|log.ltime|log.lshortfile)
}
func main() {
    info_level.println("loading the application.")
    info_level.println("loading taking time.")
    warning_level.println("there is warning.")
    debug_level.println("here is debugging information.")
    error_level.println("an error occured.")
    // read the log file
    data, err := ioutil.readfile("demo_logs.txt")
    if err != nil {
        log.panicf("failed reading data from file: %s", err)
    }
    fmt.printf("\nthe file data is : %s", data)
}

上面的代码使用 golang 的日志包创建自定义日志级别,并将日志信息写入文件。 查看输出:

the file data is : info: 2023/03/10 23:00:00 prog.go:32: loading the application.
info: 2023/03/10 23:00:00 prog.go:33: loading taking time.
warning: 2023/03/10 23:00:00 prog.go:34: there is warning.
debug: 2023/03/10 23:00:00 prog.go:35: here is debugging information.
error: 2023/03/10 23:00:00 prog.go:36: an error occured.

fatal 和 panic 级别也会导致程序或应用程序终止,这就是为什么无法使用内置日志包创建这些日志级别的原因。 但是除了日志包之外,一些第三方日志包提供了七个内置的日志级别。 让我们探索一下。


go with zerolog 中的日志级别

zerolog 是 golang 的第三方库,用于结构化 json 日志记录。 zerolog 提供了一个全局记录器,可以与 log 子包一起使用进行简单的日志记录。

除了简单的日志记录,zerolog 还提供内置的日志级别。 zerolog有七个日志级别,分别是info、warning、debug、error和trace。

zerolog 包在 github 上提供,可以使用以下命令在 golang 中下载:

$ go get -u github.com/rs/zerolog/log

使用 zerolog 使用日志级别非常简单。 请参见下面的示例:

package main
import (
    "github.com/rs/zerolog"
    "github.com/rs/zerolog/log"
)
func main() {
    zerolog.setgloballevel(zerolog.infolevel)
    log.trace().msg("tracing..")
    log.info().msg("the file is loading.")
    log.debug().msg("here is some useful debugging information.")
    log.warn().msg("there is a warning!")
    log.error().msg("an error occured.")
    log.fatal().msg("an fatal error occured.")
    log.panic().msg("this is a panic situation.")
}

上面的代码将根据日志级别记录信息。 查看输出:

{"level":"info","time":"2023-03-10t23:00:00z","message":"the file is loading."}
{"level":"warn","time":"2023-03-10t23:00:00z","message":"there is a warning!"}
{"level":"error","time":"2023-03-10t23:00:00z","message":"an error occured."}
{"level":"fatal","time":"2023-03-10t23:00:00z","message":"an fatal error occured."}

logrus 是 golang 的另一个第三方包,提供 json 日志记录。 github上提供了logrus包,可以在cmd中使用以下命令下载:

go get “github.com/sirupsen/logrus”

logrus 提供了 tracedebuginfowarnerrorfatalpanic 七种日志级别,按照严重程度排序。 使用这些日志级别也类似于我们需要使用分包日志的zerolog。

让我们尝试一个来自 logrus 的日志级别的例子:

package main
import (
    log "github.com/sirupsen/logrus"
)
func main() {
    log.setformatter(&log.jsonformatter{})
    log.setlevel(log.debuglevel)
    log.setlevel(log.tracelevel)
    //log.setlevel(log.paniclevel)
    log.trace("tracing the log info, lowest level")
    log.debug("debugging information. level two")
    log.info("log info. level three")
    log.warn("this is warning. level four")
    log.error("an error occured. level five")
    // calls os.exit(1) after logging
    log.fatal("application terminated. level six")
    // calls panic() after logging
    log.panic("panic situation. highest level.")
}

上面的代码将使用 logrus 包根据级别记录信息。 我们必须设置级别以显示某些日志级别。

查看输出:

{"level":"trace","msg":"tracing the log info, lowest level","time":"2023-03-10t23:00:00z"}
{"level":"debug","msg":"debugging information. level two","time":"2023-03-10t23:00:00z"}
{"level":"info","msg":"log info. level three","time":"2023-03-10t23:00:00z"}
{"level":"warning","msg":"this is warning. level four","time":"2023-03-10t23:00:00z"}
{"level":"error","msg":"an error occured. level five","time":"2023-03-10t23:00:00z"}
{"level":"fatal","msg":"application terminated. level six","time":"2023-03-10t23:00:00z"}

上一篇:在 go 中使用断言

下一篇:

转载请发邮件至 1244347461@qq.com 进行申请,经作者同意之后,转载请以链接形式注明出处

本文地址:

相关文章

发布时间:2023/04/27 浏览次数:101 分类:go

本篇文章介绍了在 golang 的 html 模板中使用 if-else 和 switch 循环。因此,只要输出是 html,就应该始终使用 html 模板包而不是文本模板。

发布时间:2023/04/27 浏览次数:184 分类:go

本篇文章介绍 nil 在 golang 中的含义,nil 是 go 编程语言中的零值,是众所周知且重要的预定义标识符。

golang 中的 lambda 表达式

发布时间:2023/04/27 浏览次数:691 分类:go

本篇文章介绍如何在 golang 中创建 lambda 表达式。lambda 表达式似乎不存在于 golang 中。 函数文字、lambda 函数或闭包是匿名函数的另一个名称。

发布时间:2023/04/27 浏览次数:136 分类:go

当我们尝试生成对象的副本时,深层副本会准确复制原始对象的所有字段。 此外,如果它有任何对象作为字段,也会制作这些对象的副本。本篇文章介绍如何在 golang 中进行深度复制。

发布时间:2023/04/27 浏览次数:104 分类:go

像错误一样,panic 发生在运行时。 换句话说,当您的 go 程序中出现意外情况导致执行终止时,就会发生 panics。让我们看一些例子来捕捉 golang 中的panics。

在 go 中使用断言

发布时间:2023/04/27 浏览次数:585 分类:go

本篇文章介绍了 assert 在 golang 中的使用。在 go 语言中使用断言:golang 不提供对断言的任何内置支持,但我们可以使用来自 testify api 的广泛使用的第三方包断言。

go 中的随机数生成

发布时间:2023/04/27 浏览次数:206 分类:go

本篇文章介绍如何在 go 语言中使用随机数生成功能。go 中的随机数生成 go 语言为随机数生成功能提供内置支持。 内置包 math 有方法 rand(),用于随机数生成。

golang 电子邮件验证器

发布时间:2023/04/27 浏览次数:300 分类:go

本篇文章介绍如何在 go 语言中验证电子邮件。电子邮件需要特定格式; 否则,它们将无法工作。

卸载 golang

发布时间:2023/04/27 浏览次数:519 分类:go

本篇文章介绍如何在不同的操作系统上卸载 golang。卸载 go 语言 只需几个简单的步骤即可卸载 golang。 这些步骤对于不同的操作系统是不同的。

扫一扫阅读全部技术教程

社交账号
  • https://www.github.com/onmpw
  • qq:1244347461

最新推荐

教程更新

热门标签

扫码一下
查看教程更方便
网站地图