分享
  1. 首页
  2. 文章

gin框架之log处理

寒云暮雨 · · 15950 次点击 · · 开始浏览
这是一个创建于 的文章,其中的信息可能已经有所发展或是发生改变。

我们在开发的过程中往往需要记录日志,记录日志可以帮我们追踪错误,追踪业务需求。那么gin中是如何记录日志的呢?


package main
import (
 "github.com/gin-gonic/gin"
 "io"
 "os"
)
func main() {
 // 记录到文件。
 f, _ := os.Create("gin.log")
 gin.DefaultWriter = io.MultiWriter(f)
 router := gin.Default()
 router.Run()
}

我们自定义了log的记录方式,但是这种方式国语简单,不利于我们收集错误信息。在这里为大家推荐一个记录日志的库github.com/sirupsen/logrus。logrus是目前Github上star数量最多的日志库.

logrus特性

  1. 完全兼容golang标准库日志模块:logrus拥有六种日志级别:debug、info、warn、error、fatal和panic,这是golang标准库日志模块的API的超集。如果您的项目使用标准库日志模块,完全可以以最低的代价迁移到logrus上。
  2. 可扩展的Hook机制:允许使用者通过hook的方式将日志分发到任意地方,如本地文件系统、标准输出、logstash、elasticsearch或者mq等,或者通过hook定义日志内容和格式等。
  3. 可选的日志输出格式:logrus内置了两种日志格式,JSONFormatter和TextFormatter,如果这两个格式不满足需求,可以自己动手实现接口Formatter,来定义自己的日志格式。
    Field机制:logrus鼓励通过Field机制进行精细化的、结构化的日志记录,而不是通过冗长的消息来记录日志。
    logrus是一个可插拔的、结构化的日志框架。

package main
import (
 "fmt"
 "github.com/gin-gonic/gin"
 "github.com/sirupsen/logrus"
 "os"
 "path"
 "time"
)
func Logger() *logrus.Logger {
 now := time.Now()
 logFilePath := ""
 if dir, err := os.Getwd(); err == nil {
 logFilePath = dir + "/logs/"
 }
 if err := os.MkdirAll(logFilePath, 0777); err != nil {
 fmt.Println(err.Error())
 }
 logFileName := now.Format("2006年01月02日") + ".log"
 //日志文件
 fileName := path.Join(logFilePath, logFileName)
 if _, err := os.Stat(fileName); err != nil {
 if _, err := os.Create(fileName); err != nil {
 fmt.Println(err.Error())
 }
 }
 //写入文件
 src, err := os.OpenFile(fileName, os.O_APPEND|os.O_WRONLY, os.ModeAppend)
 if err != nil {
 fmt.Println("err", err)
 }
 //实例化
 logger := logrus.New()
 //设置输出
 logger.Out = src
 //设置日志级别
 logger.SetLevel(logrus.DebugLevel)
 //设置日志格式
 logger.SetFormatter(&logrus.TextFormatter{
 TimestampFormat: "2006年01月02日 15:04:05",
 })
 return logger
}
func LoggerToFile() gin.HandlerFunc {
 logger := Logger()
 return func(c *gin.Context) {
 // 开始时间
 startTime := time.Now()
 // 处理请求
 c.Next()
 // 结束时间
 endTime := time.Now()
 // 执行时间
 latencyTime := endTime.Sub(startTime)
 // 请求方式
 reqMethod := c.Request.Method
 // 请求路由
 reqUri := c.Request.RequestURI
 // 状态码
 statusCode := c.Writer.Status()
 // 请求IP
 clientIP := c.ClientIP()
 //日志格式
 logger.Infof("| %3d | %13v | %15s | %s | %s |",
 statusCode,
 latencyTime,
 clientIP,
 reqMethod,
 reqUri,
 )
 }
}
func main() {
 // 记录到文件。
 router := gin.Default()
 router.Use(LoggerToFile())
 router.GET("/", func(context *gin.Context) {
 //Info级别的日志
 Logger().WithFields(logrus.Fields{
 "name": "hanyun",
 }).Info("记录一下日志", "Info")
 //Error级别的日志
 Logger().WithFields(logrus.Fields{
 "name": "hanyun",
 }).Error("记录一下日志", "Error")
 //Warn级别的日志
 Logger().WithFields(logrus.Fields{
 "name": "hanyun",
 }).Warn("记录一下日志", "Warn")
 //Debug级别的日志
 Logger().WithFields(logrus.Fields{
 "name": "hanyun",
 }).Debug("记录一下日志", "Debug")
 })
 router.Run()
}

我们在路由中间件中使用了自定的日志中间件

 router.Use(LoggerToFile())

当然了,这个日志库还可以将日志发送到elasticsearch,有兴趣的小伙伴可以尝试一下。
奉上代码,喜欢的小伙伴可以去自行下载
链接:https://pan.baidu.com/s/1fFsogIpPssm35CWV6H8m-g
提取码:xu7m

image

有疑问加站长微信联系(非本文作者)

本文来自:简书

感谢作者:寒云暮雨

查看原文:gin框架之log处理

入群交流(和以上内容无关):加入Go大咖交流群,或添加微信:liuxiaoyan-s 备注:入群;或加QQ群:692541889

关注微信
15950 次点击
暂无回复
添加一条新回复 (您需要 后才能回复 没有账号 ?)
  • 请尽量让自己的回复能够对别人有帮助
  • 支持 Markdown 格式, **粗体**、~~删除线~~、`单行代码`
  • 支持 @ 本站用户;支持表情(输入 : 提示),见 Emoji cheat sheet
  • 图片支持拖拽、截图粘贴等方式上传

用户登录

没有账号?注册
(追記) (追記ここまで)

今日阅读排行

    加载中
(追記) (追記ここまで)

一周阅读排行

    加载中

关注我

  • 扫码关注领全套学习资料 关注微信公众号
  • 加入 QQ 群:
    • 192706294(已满)
    • 731990104(已满)
    • 798786647(已满)
    • 729884609(已满)
    • 977810755(已满)
    • 815126783(已满)
    • 812540095(已满)
    • 1006366459(已满)
    • 692541889

  • 关注微信公众号
  • 加入微信群:liuxiaoyan-s,备注入群
  • 也欢迎加入知识星球 Go粉丝们(免费)

给该专栏投稿 写篇新文章

每篇文章有总共有 5 次投稿机会

收入到我管理的专栏 新建专栏