iis服务器助手广告广告
返回顶部
首页 > 资讯 > 后端开发 > GO >go日志库logrus的安装及快速使用
  • 924
分享到

go日志库logrus的安装及快速使用

2024-04-02 19:04:59 924人浏览 薄情痞子
摘要

目录安装简介快速使用支持的日志级别日期打印调用位置添加字段给字段值加引号设置钩子设置channel输出日志安装简介 Logrus是Go的结构化日志记录器,与标准的日志记录器库完全ap

安装简介

Logrus是Go的结构化日志记录器,与标准的日志记录器库完全api兼容。

go get安装的logrus库

 go get GitHub.com/sirupsen/logrus

快速使用

package main
import (
   log "github.com/sirupsen/logrus"
)
func main() {
   log.SetLevel(log.TraceLevel)
   log.Trace("trace")
   log.Debug("debug")
   log.Info("info")
   log.Warn("warn")
   log.Error("error")
   log.Fatal("fatal")
   log.Panic("panic")
}

输出:

TRAC[0000] trace                                        
DEBU[0000] debug                                        
INFO[0000] info                                         
WARN[0000] warn                                         
ERRO[0000] error                                        
FATA[0000] fatal                                        
exit status 1

可以看到panic没有输出,因为fatal会导致goroutine直接退出。

支持的日志级别

logrus支持多种日志级别,下面从小到大:

  • Panic:记录日志,然后panic
  • Fatal:致命错误,输出日志后,程序退出
  • Error:错误
  • Warn:警告
  • Info:关键信息
  • Debug:调试信息
  • Trace:很细粒度的信息,一般用不到。

可以看到Trace级别最大,Panic最小。默认的级别为Info,高于这个级别的日志不会输出。

日期

可以看到上面的日志没有时间,可以指定日志格式:

package main
import (
   log "github.com/sirupsen/logrus"
)
func main() {
   log.SetLevel(log.TraceLevel)
   log.SetFORMatter(&log.TextFormatter{
      FullTimestamp:   true,
      TimestampFormat: "2022-07-17 00:00:00.000",
   })
   log.Trace("trace")
   log.Debug("debug")
   log.Info("info")
   log.Warn("warn")
   log.Error("error")
   log.Fatal("fatal")
   log.Panic("panic")
}

精确到毫秒。

输出:

TRAC[171717+08-77 00:00:00.628] trace                                        
DEBU[171717+08-77 00:00:00.629] debug                                        
INFO[171717+08-77 00:00:00.629] info                                         
WARN[171717+08-77 00:00:00.629] warn                                         
ERRO[171717+08-77 00:00:00.629] error                                        
FATA[171717+08-77 00:00:00.629] fatal                                        
exit status 1

打印调用位置

在进行定位的时候需要知道是那行代码调用的log.SetReportCaller(true)

package main
import (
   log "github.com/sirupsen/logrus"
)
func main() {
   log.SetLevel(log.TraceLevel)
   log.SetReportCaller(true)
   log.SetFormatter(&log.TextFormatter{
      FullTimestamp:   true,
      TimestampFormat: "2022-07-17 00:00:00.000",
   })
   log.Trace("trace")
   log.Debug("debug")
   log.Info("info")
   log.Warn("warn")
   log.Error("error")
   log.Fatal("fatal")
   log.Panic("panic")
}

输出:

TRAC[171717+08-77 00:00:00.019]/Users/wanghaifeng/GolandProjects/StudyProject/src/log/my_log.go:14 main.main() trace                                        
DEBU[171717+08-77 00:00:00.019]/Users/wanghaifeng/GolandProjects/StudyProject/src/log/my_log.go:15 main.main() debug                                        
INFO[171717+08-77 00:00:00.019]/Users/wanghaifeng/GolandProjects/StudyProject/src/log/my_log.go:16 main.main() info                                         
WARN[171717+08-77 00:00:00.019]/Users/wanghaifeng/GolandProjects/StudyProject/src/log/my_log.go:17 main.main() warn                                         
ERRO[171717+08-77 00:00:00.019]/Users/wanghaifeng/GolandProjects/StudyProject/src/log/my_log.go:18 main.main() error                                        
FATA[171717+08-77 00:00:00.019]/Users/wanghaifeng/GolandProjects/StudyProject/src/log/my_log.go:19 main.main() fatal                                        
exit status 1

添加字段

定位问题需要知道具体是那个数据调用的,可以借助于log.WithFieldlog.WithFieldslog.WithField内部调用的也是log.WithFields,参数底层使用map[string]interface{}数据结构保存:

package main
import (
   log "github.com/sirupsen/logrus"
   "os"
)
func main() {
   log.SetLevel(log.TraceLevel)
   log.SetReportCaller(true)
   log.SetFormatter(&log.TextFormatter{
      FullTimestamp:   true,
      TimestampFormat: "2022-07-17 00:00:00.000",
   })
   id := os.Args[1]
   mylog := log.WithField("id", id)
   mylog.Trace("trace")
   mylog.Debug("debug")
   mylog.Info("info")
   mylog.Warn("warn")
   mylog.Error("error")
   mylog.Fatal("fatal")
   mylog.Panic("panic")
}

输出:

➜  StudyProject go run  src/log/my_log.go 123
TRAC[171717+08-77 00:00:00.665]/Users/wanghaifeng/GolandProjects/StudyProject/src/log/my_log.go:22 main.main() trace                                         id=123
DEBU[171717+08-77 00:00:00.665]/Users/wanghaifeng/GolandProjects/StudyProject/src/log/my_log.go:23 main.main() debug                                         id=123
INFO[171717+08-77 00:00:00.665]/Users/wanghaifeng/GolandProjects/StudyProject/src/log/my_log.go:24 main.main() info                                          id=123
WARN[171717+08-77 00:00:00.665]/Users/wanghaifeng/GolandProjects/StudyProject/src/log/my_log.go:25 main.main() warn                                          id=123
ERRO[171717+08-77 00:00:00.665]/Users/wanghaifeng/GolandProjects/StudyProject/src/log/my_log.go:26 main.main() error                                         id=123
FATA[171717+08-77 00:00:00.665]/Users/wanghaifeng/GolandProjects/StudyProject/src/log/my_log.go:27 main.main() fatal                                         id=123
exit status 1

给字段值加引号

配置ForceQuotetrue

package main
import (
   log "github.com/sirupsen/logrus"
   "os"
)
func main() {
   log.SetLevel(log.TraceLevel)
   log.SetReportCaller(true)
   log.SetFormatter(&log.TextFormatter{
      FullTimestamp:   true,
      TimestampFormat: "2022-07-17 00:00:00.000",
      ForceQuote:      true,
   })
   id := os.Args[1]
   mylog := log.WithField("id", id)
   mylog.Trace("trace")
   mylog.Debug("debug")
   mylog.Info("info")
   mylog.Warn("warn")
   mylog.Error("error")
   mylog.Fatal("fatal")
   mylog.Panic("panic")
}

输出:

➜  StudyProject go run  src/log/my_log.go 123
TRAC[171717+08-77 00:00:00.427]/Users/wanghaifeng/GolandProjects/StudyProject/src/log/my_log.go:22 main.main() trace                                         id="123"
DEBU[171717+08-77 00:00:00.427]/Users/wanghaifeng/GolandProjects/StudyProject/src/log/my_log.go:23 main.main() debug                                         id="123"
INFO[171717+08-77 00:00:00.427]/Users/wanghaifeng/GolandProjects/StudyProject/src/log/my_log.go:24 main.main() info                                          id="123"
WARN[171717+08-77 00:00:00.427]/Users/wanghaifeng/GolandProjects/StudyProject/src/log/my_log.go:25 main.main() warn                                          id="123"
ERRO[171717+08-77 00:00:00.427]/Users/wanghaifeng/GolandProjects/StudyProject/src/log/my_log.go:26 main.main() error                                         id="123"
FATA[171717+08-77 00:00:00.427]/Users/wanghaifeng/GolandProjects/StudyProject/src/log/my_log.go:27 main.main() fatal                                         id="123"
exit status 1

设置钩子

每条日志在输出前都会执行钩子的特定方法,相当于全局拦截,可以方便做一些扩展,比如添加字段channel表明日志是那个应用输出的、增加tranceid方便对问题的跟踪、输出日志文件等。

设置channel

package hooks
import log "github.com/sirupsen/logrus"
type ChannelHook struct {
   ChannelName string
}
func (h ChannelHook) Levels() []log.Level {
   return log.AllLevels
}
func (h ChannelHook) Fire(entry *log.Entry) error {
   entry.Data["channel"] = h.ChannelName
   return nil
}
package main
import (
   logs "StudyProject/src/log/hooks"
   log "github.com/sirupsen/logrus"
)
func main() {
   log.AddHook(logs.ChannelHook{
      ChannelName: "WEB",
   })
   log.Info("info")
}

输出:

INFO[0000] info                                          channel=web

输出日志

可以利用logrus的hook自己写入文件,但是指定单个文件收集的时间范围、保存的时间logrus并不支持,笔者目前的项目使用的是file-rotatelogs,但是作者已经不更新和维护,所以这里就不使用它来展示,有在考虑使用goframe的glog替换。

笔者这里就写个简单例子演示如何利用logrus的hook去写文件并且把控制台的打印干掉:

package hooks
import (
   log "github.com/sirupsen/logrus"
   "io/ioutil"
)
//
//FileHook
//  @Description: 文件hook
//
type FileHook struct {
   //
   //  FileName
   //  @Description:  文件名
   //
   FileName string
}
func (h FileHook) Levels() []log.Level {
   return log.AllLevels
}
func (h FileHook) Fire(entry *log.Entry) error {
   fomat := &log.TextFormatter{
      FullTimestamp:   true,
      TimestampFormat: "2022-07-17 00:00:00.000",
   }
   //  从entry从获得日志内容
   msg, err := fomat.Format(entry)
   if err != nil {
      return err
   }
   err = ioutil.WriteFile(h.FileName, msg, 0644)
   if err != nil {
      return err
   }
   return nil
}
package main
import (
   logs "StudyProject/src/log/hooks"
   log "github.com/sirupsen/logrus"
   "io/ioutil"
)
func main() {
   log.AddHook(logs.FileHook{"log"})
   //  关闭控制台打印
   log.SetOutput(ioutil.Discard)
   log.Info("test log write file")
}

很显然这只是个例子,不可直接应用于生产。

以上就是go日志库logrus的安装及快速使用的详细内容,更多关于go日志库logrus安装使用的资料请关注编程网其它相关文章!

您可能感兴趣的文档:

--结束END--

本文标题: go日志库logrus的安装及快速使用

本文链接: https://www.lsjlt.com/news/120994.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • go日志库logrus的安装及快速使用
    目录安装简介快速使用支持的日志级别日期打印调用位置添加字段给字段值加引号设置钩子设置channel输出日志安装简介 Logrus是Go的结构化日志记录器,与标准的日志记录器库完全AP...
    99+
    2024-04-02
  • go日志库中的logrus
    一、安装 go get github.com/sirupsen/logrus 二、使用 1、当做标准库使用 logrus实现了标准库log的方法,可以用标准库的方法用于logrus,...
    99+
    2024-04-02
  • GO语言中的日志响应速度有多快?
    随着互联网技术的不断发展,系统日志已经成为了一个重要的组成部分。而在GO语言中,日志输出是一个非常常见的操作,很多开发者都会使用GO语言自带的日志库进行日志输出操作。那么,GO语言中的日志响应速度有多快呢?本文将会为您进行详细的介绍。 G...
    99+
    2023-07-02
    索引 日志 响应
  • OpenCV快速安装指南:使用pip安装
    使用pip快速安装OpenCV教程 引言:OpenCV(Open Source Computer Vision)是一个开源的计算机视觉库,它提供了丰富的图像和视频处理函数,可以用于实现各种计算机视觉任务,如人脸识别、目标追踪、图...
    99+
    2024-01-18
    OpenCV 教程 pip
  • C++第三方日志库Glog的安装与使用介绍
    目录一、glog介绍二、glog下载三、环境介绍三、glog的编译详解3.1 利用CMake进行编译,生成VS解决方案3.2 利用VS对项目进行编译四、glog的基本使用4.1 创建...
    99+
    2024-04-02
  • Go语言Zap日志库如何使用
    这篇“Go语言Zap日志库如何使用”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“Go语言Zap日志库如何使用”文章吧。一、日...
    99+
    2023-07-05
  • GO实时日志框架:如何快速地记录和查看你的应用程序日志?
    日志记录是应用程序开发中非常重要的一环。它是帮助开发人员调试和排查问题的重要手段。在开发过程中,我们需要将程序运行时的信息记录到日志文件中,这样可以在应用程序出现问题时追踪问题的根源。在GO语言中,有许多实时日志框架可以帮助我们实现这一目...
    99+
    2023-10-14
    实时 日志 框架
  • 如何利用Go语言快速打包大量日志数据?
    Go语言是一种高效的编程语言,拥有着出色的并发处理能力和快速的执行速度。因此,它成为了越来越多开发者的选择。在这篇文章中,我们将介绍如何利用Go语言快速打包大量日志数据。 什么是日志数据 在计算机领域,日志数据是指记录了程序运行过程中所...
    99+
    2023-09-01
    大数据 日志 打包
  • debian11.7 快速安装及常用功能处理
    一、debian11.7 安装 1.1、下载镜像,不要选择默认的网络镜像,选择那个3.5-4G的镜像, debian-11.7.0-amd64-DVD-1.iso 1.2、移除网络  把wifi或者网线断掉 1.3、快速安装 Debian1...
    99+
    2023-10-26
    linux
  • httplib库的安装以及使用
    目录 安装httplib库 认识httplib库 httplib请求类  httplib响应类  httplib中的Server类        httplib的client类 httplib库搭建简单的服务器 httplib库搭建简单的客...
    99+
    2023-09-17
    服务器 http 前端
  • 如何使用安装日志排查Office中的安装问题
    要使用安装日志排查Office中的安装问题,您可以按照以下步骤操作:1. 打开“控制面板”并选择“程序”(或“程序和功能”)。2. ...
    99+
    2023-09-08
    Office
  • C++第三方日志库log4cplus的安装与使用配置教程
    目录一、log4cplus介绍二、log4cplus下载三、log4cplus配置3.1 打开解决方案3.2 进行相应设置3.3 目标程序的配置四、测试Demo一、log4cplus...
    99+
    2024-04-02
  • 怎么使用Cobbler快速安装系统
    这篇文章主要为大家展示了“怎么使用Cobbler快速安装系统”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“怎么使用Cobbler快速安装系统”这篇文章吧。Cobbler 可以用来快速建立 Lin...
    99+
    2023-06-27
  • GO语言框架快速集成日志模块的操作方法
    目录前言zap包的集成简介最基础的使用定制化进阶封装前言 在我们的日常开发中, 日志模块永远是最基础且最重要的一个模块, 它可以有效的帮我们发现问题, 定位问题, 最后去解决问题; ...
    99+
    2024-04-02
  • GO语言的日志响应速度比其他语言快多少?
    随着云计算、大数据、人工智能等技术的不断发展,日志系统的重要性越来越凸显出来。在开发过程中,我们经常会使用日志来记录程序的运行状态,以便于分析和调试。但是,日志系统的性能却往往成为制约程序性能的瓶颈。因此,在选择日志框架时,我们需要考虑其...
    99+
    2023-07-02
    索引 日志 响应
  • 使用MDC快速查询应用接口全部执行日志
    目录引言引言 对于每一个开发者来说,查询接口的执行日志都是一个高频率的操作,每当测试说接口有问题时,我们都需要去服务器或者日志系统上查报错的原因。 一般情况下,我们会通过对应的关键...
    99+
    2023-01-08
    MDC查询接口执行日志 MDC 查询接口
  • 如何使用Go语言优化Laravel日志加载速度?
    随着互联网技术的发展,Web应用程序的开发越来越受到人们的关注。Laravel是一个流行的PHP Web框架,它提供了丰富的功能和易于使用的API,使得Web应用程序的开发变得更加简单和高效。然而,Laravel在处理日志时,会遇到一些性能...
    99+
    2023-10-18
    load laravel 日志
  • C++日志库log4cplus的使用详解
    目录编译&&安装编写demo项目中需要打印log,方便程序调试和问题定位分析。C++实现的log4cplus日志库是一种易于使用的C ++日志记录API,可提供线程安...
    99+
    2023-03-01
    C++日志库log4cplus使用 C++ log4cplus C++日志库log4cplus
  • 在Go语言项目中怎么使用Zap日志库
    本篇内容介绍了“在Go语言项目中怎么使用Zap日志库”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!在Go语言项目中使用Zap日志库介绍在许多...
    99+
    2023-06-30
  • 快速掌握在Linux上安装Go语言的方法
    在Linux上安装Go语言是开发者们开始使用这门编程语言的第一步。Go语言是一门由Google开发的开源编程语言,其简单易学的特点吸引了众多开发者的青睐。本文将介绍如何在Linux系统...
    99+
    2024-03-13
    linux go语言 安装 系统版本
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作