当前位置:首页 > 科技  > 软件

盘点 Go 语言的那些日志库:你用了哪个?

来源: 责编: 时间:2023-09-28 10:09:37 447观看
导读大家好,我是站长 polarisxu。Go语言是一种高性能、简洁、并发友好的编程语言,广泛用于开发各种应用程序,如网络服务、微服务、云计算、区块链等。Go语言的标准库提供了一个基本的日志包(log),可以用于记录简单的日志信息,如

大家好,我是站长 polarisxu。rJM28资讯网——每日最新资讯28at.com

Go语言是一种高性能、简洁、并发友好的编程语言,广泛用于开发各种应用程序,如网络服务、微服务、云计算、区块链等。Go语言的标准库提供了一个基本的日志包(log),可以用于记录简单的日志信息,如时间、级别、消息等。但是,如果你需要更多的功能和灵活性,例如结构化日志、日志旋转、日志钩子、日志格式化等,那么你可能需要使用第三方的日志库。rJM28资讯网——每日最新资讯28at.com

在本文中,我们将介绍Go语言中最流行和最优秀的日志库,并给出每个库的使用示例代码。我们将按照以下的大纲来介绍这些日志库:rJM28资讯网——每日最新资讯28at.com

  • Zap
  • log/slog
  • Logrus
  • Zerolog
  • Glog

Zap

Zap 是一个快速、结构化、分级和可扩展的日志库,由Uber开发和维护。Zap提供了两种不同的API:SugaredLogger和Logger。SugaredLogger支持结构化和非结构化的日志记录,但是牺牲了一些性能。Logger只支持结构化的日志记录,但是具有更高的性能和更低的内存分配。rJM28资讯网——每日最新资讯28at.com

Zap还提供了一些有用的特性,如:rJM28资讯网——每日最新资讯28at.com

  • 可以自定义日志级别、输出目标、编码器(JSON或控制台)、时间格式等。
  • 可以使用字段(Fields)来添加结构化的上下文信息,如键值对。
  • 可以使用钩子(Hooks)来在每次写入日志时执行一些操作,如发送邮件、写入数据库等。
  • 可以使用取样器(Sampler)来限制每秒写入的日志数量,以减少性能开销。
  • 可以使用核心(Core)来组合多个输出目标和编码器。

以下是一个使用Zap的示例代码:rJM28资讯网——每日最新资讯28at.com

package mainimport ( "go.uber.org/zap")func main() { // 创建一个 Logger logger, err := zap.NewDevelopment() if err != nil {  panic(err) } defer logger.Sync() sugar := logger.Sugar() // 使用SugaredLogger记录非结构化的日志 sugar.Infow("This is a structured log",  "key1", "value1",  "key2", "value2", ) // 使用SugaredLogger记录结构化的日志 sugar.Infof("This is an unstructured log: %s", "hello world") // 创建一个Logger logger, err = zap.NewProduction() if err != nil {  panic(err) } defer logger.Sync() // 使用Logger记录结构化的日志 logger.Info("This is a structured log",  zap.String("key1", "value1"),  zap.String("key2", "value2"), ) // 使用Logger记录错误级别的日志,并添加堆栈跟踪信息 logger.Error("This is an error log",  zap.Error(err),  zap.Stack("stack"), )}

log/slog

log/slog是Go 1.21中引入的一个新的结构化日志库,它与标准库的log包兼容,但提供了更多的功能和灵活性。log/slog定义了一个类型,Logger,用于记录不同级别和格式的日志信息。每个Logger都关联一个Handler,用于处理日志记录。log/slog还提供了一个默认的Logger,可以通过顶级函数(如Info和Error)来使用,它们会调用相应的Logger方法。该默认Logger将日志信息写入标准错误,并在每条日志信息前添加日期和时间。rJM28资讯网——每日最新资讯28at.com

log/slog的日志记录由以下几个部分组成:rJM28资讯网——每日最新资讯28at.com

  • 时间:日志记录发生的时间,可以是本地时间或UTC时间。
  • 级别:日志记录的严重程度,可以是预定义的四个级别之一(Debug、Info、Warn、Error),也可以是自定义的整数值。
  • 消息:日志记录的主要内容,通常是一个简短的描述性字符串。
  • 属性:日志记录的额外信息,以键值对的形式表示,键是字符串,值可以是任意类型。

例如,以下代码:rJM28资讯网——每日最新资讯28at.com

package mainimport ( "log/slog" "os")func main() { slog.Info("hello, world", "user", os.Getenv("USER"))}

会产生以下输出:rJM28资讯网——每日最新资讯28at.com

2023/09/09 16:27:19 INFO hello, world user=polarisxu

其中,2023/09/09 16:27:19是时间,INFO是级别,hello, world是消息,user=polarisxu是属性。rJM28资讯网——每日最新资讯28at.com

log/slog还提供了一些有用的特性,如:rJM28资讯网——每日最新资讯28at.com

  • 可以自定义日志级别、输出目标、格式器(JSON或文本)、时间戳等。
  • 可以使用字段(Fields)来添加结构化的上下文信息,如键值对。
  • 可以使用处理器(Handler)来处理不同级别或条件的日志信息,如过滤、分割、彩色等。
  • 可以使用条目(Entry)来记录带有字段的日志信息,或者使用WithFields、WithTime、WithError等方法来创建带有字段的条目。
  • 可以使用日志级别函数(如Info、Warn、Error等)来记录不同级别的日志信息,或者使用Log或Print等方法来记录默认级别的日志信息。

以下是一个使用log/slog的示例代码:rJM28资讯网——每日最新资讯28at.com

package mainimport ( "log/slog" "os")func main() { // 创建一个JSON处理器 jsonHandler := slog.NewJSONHandler(os.Stdout, nil) // 创建一个文本处理器 textHandler := slog.NewTextHandler(os.Stderr, nil) // 创建一个文本 Logger textLogger := slog.New(textHandler) // 创建一个 JSON Logger jsonLogger := slog.New(jsonHandler) // 使用Logger记录结构化的日志信息 textLogger.Info("hello, world", "user", os.Getenv("USER")) // 使用Logger记录结构化的日志信息 jsonLogger.Info("hello, world", "user", os.Getenv("USER"))}

该程序会在标准错误上输出文本格式的日志信息:rJM28资讯网——每日最新资讯28at.com

time=2023-09-09T16:27:19.000-05:00 level=INFO msg=hello, world user=polarisxu

然后在标准输出上输出JSON格式的日志信息:rJM28资讯网——每日最新资讯28at.com

{"time":"2023-09-09T16:27:19.000000000-05:00","level":"INFO","msg":"hello","user":"polarisxu"}

Logrus

Logrus是一个结构化、分级、可扩展和兼容标准库log包的日志库,由Sirupsen开发和维护。Logrus提供了一个简单而强大的API,可以用于记录不同级别和格式的日志信息。rJM28资讯网——每日最新资讯28at.com

Logrus也提供了一些有用的特性,如:rJM28资讯网——每日最新资讯28at.com

  • 可以自定义日志级别、输出目标、格式器(JSON或文本)、时间戳等。
  • 可以使用字段(Fields)来添加结构化的上下文信息,如键值对。
  • 可以使用钩子(Hooks)来在每次写入日志时执行一些操作,如发送邮件、写入数据库等。
  • 可以使用条目(Entry)来记录带有字段的日志信息,或者使用WithFields、WithTime、WithError等方法来创建带有字段的条目。
  • 可以使用日志级别函数(如Info、Warn、Error等)来记录不同级别的日志信息,或者使用Log或Print等方法来记录默认级别的日志信息。

以下是一个使用Logrus的示例代码:rJM28资讯网——每日最新资讯28at.com

package mainimport ( "os" "github.com/sirupsen/logrus")func main() { // 创建一个Logrus实例 log := logrus.New() // 设置日志级别为Debug log.SetLevel(logrus.DebugLevel) // 设置输出目标为标准输出 log.SetOutput(os.Stdout) // 设置格式器为JSON log.SetFormatter(&logrus.JSONFormatter{}) // 使用Fields添加结构化的上下文信息 log.WithFields(logrus.Fields{  "key1": "value1",  "key2": "value2", }).Info("This is a structured log") // 使用Entry记录带有字段的日志信息 entry := log.WithFields(logrus.Fields{  "key3": "value3",  "key4": "value4", }) entry.Warn("This is another structured log") // 使用日志级别函数记录不同级别的日志信息 log.Debug("This is a debug log") log.Info("This is an info log") log.Warn("This is a warn log") log.Error("This is an error log") log.Fatal("This is a fatal log") log.Panic("This is a panic log") // 使用Log或Print等方法记录默认级别的日志信息 log.Log(logrus.InfoLevel, "This is a log with level") log.Print("This is a print log")}

Zerolog

Zerolog是一个快速、简单、零内存分配的结构化日志库,由rs开发和维护。Zerolog提供了一个流式(Fluent)的API,可以用于记录不同级别和格式的日志信息。rJM28资讯网——每日最新资讯28at.com

Zerolog也提供了一些有用的特性,如:rJM28资讯网——每日最新资讯28at.com

  • 可以自定义日志级别、输出目标、编码器(JSON或控制台)、时间格式等。
  • 可以使用字段(Fields)来添加结构化的上下文信息,如键值对。
  • 可以使用钩子(Hooks)来在每次写入日志时执行一些操作,如发送邮件、写入数据库等。
  • 可以使用取样器(Sampler)来限制每秒写入的日志数量,以减少性能开销。
  • 可以使用上下文(Context)来创建带有字段的日志记录器,或者使用With、Dict等方法来添加字段。

以下是一个使用Zerolog的示例代码:rJM28资讯网——每日最新资讯28at.com

package mainimport ( "os" "github.com/rs/zerolog" "github.com/rs/zerolog/log")func main() { // 设置日志级别为Debug zerolog.SetGlobalLevel(zerolog.DebugLevel) // 设置输出目标为标准输出 log.Logger = log.Output(zerolog.ConsoleWriter{Out: os.Stdout}) // 使用Fields添加结构化的上下文信息 log.Info().  Str("key1", "value1").  Str("key2", "value2").  Msg("This is a structured log") // 使用Context创建带有字段的日志记录器 sublogger := log.With().  Str("key3", "value3").  Logger() sublogger.Warn().  Str("key4", "value4").  Msg("This is another structured log") // 使用日志级别函数记录不同级别的日志信息 log.Debug().Msg("This is a debug log") log.Info().Msg("This is an info log") log.Warn().Msg("This is a warn log") log.Error().Msg("This is an error log") log.Fatal().Msg("This is a fatal log") log.Panic().Msg("This is a panic log")}

总结

在本文中,我们介绍了Go语言中最流行和最优秀的日志库,并给出了每个库的使用示例代码。这些日志库都有各自的优点和特点,可以根据你的需求和喜好来选择合适的日志库。rJM28资讯网——每日最新资讯28at.com

本文链接:http://www.28at.com/showinfo-26-11901-0.html盘点 Go 语言的那些日志库:你用了哪个?

声明:本网页内容旨在传播知识,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。邮件:2376512515@qq.com

上一篇: 十年老后端运行公司前端项目,连编译都没过去...问题出在哪?

下一篇: 我们一起再玩玩B端搭建

标签:
  • 热门焦点
  • 6月安卓手机性价比榜:Note 12 Turbo断层式碾压

    6月份有一个618,虽然这是京东周年庆的日子,但别的电商也都不约而同的跟进了,反正促销没坏处,厂商和用户都能满意。618期间一些产品也出现了历史低价,那么各个价位段的产品性价比
  • 2023 年的 Node.js 生态系统

    随着技术的不断演进和创新,Node.js 在 2023 年达到了一个新的高度。Node.js 拥有一个庞大的生态系统,可以帮助开发人员更快地实现复杂的应用。本文就来看看 Node.js 最新的生
  • 把LangChain跑起来的三个方法

    使用LangChain开发LLM应用时,需要机器进行GLM部署,好多同学第一步就被劝退了,那么如何绕过这个步骤先学习LLM模型的应用,对Langchain进行快速上手?本片讲解3个把LangChain跑起来
  • 一年经验在二线城市面试后端的经验分享

    忠告这篇文章只适合2年内工作经验、甚至没有工作经验的朋友阅读。如果你是2年以上工作经验,请果断划走,对你没啥帮助~主人公这篇文章内容来自 「升职加薪」星球星友 的投稿,坐
  • 三言两语说透设计模式的艺术-单例模式

    写在前面单例模式是一种常用的软件设计模式,它所创建的对象只有一个实例,且该实例易于被外界访问。单例对象由于只有一个实例,所以它可以方便地被系统中的其他对象共享,从而减少
  • ESG的面子与里子

    来源 | 光子星球撰文 | 吴坤谚编辑 | 吴先之三伏大幕拉起,各地高温预警不绝,但处于厄尔尼诺大“烤”之下的除了众生,还有各大企业发布的ESG报告。ESG是“环境保
  • 携众多高端产品亮相ChinaJoy,小米带来一场科技与人文的视听盛宴

    7月28日,全球数字娱乐领域最具知名度与影响力的年度盛会中国国际数码互动娱乐展览会(简称ChinaJoy)在上海新国际博览中心盛大开幕。作为全球领先的科
  • 超闭合精工铰链 彻底消灭缝隙 三星Galaxy Z Flip5与Galaxy Z Fold5发布

    2023年7月26日,三星电子正式发布了Galaxy Z Flip5与Galaxy Z Fold5。三星新一代折叠屏手机采用超闭合精工铰链,让折叠后的缝隙不再可见。同时,配合处
  • 机构称Q2全球智能手机出货量同比下滑11% 苹果份额依旧第2

    7月20日消息,据外媒报道,研究机构的报告显示,由于需求下滑,今年二季度全球智能手机的出货量,同比下滑了11%,三星、苹果等主要厂商的销量,较去年同期均有下
Top