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特性
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())
最终的日志格式如下
time="2020-03-09 17:23:00" level=info msg="记录一下日志Info" name=hanyun
time="2020-03-09 17:23:00" level=error msg="记录一下日志Error" name=hanyun
time="2020-03-09 17:23:00" level=warning msg="记录一下日志Warn" name=hanyun
time="2020-03-09 17:23:00" level=debug msg="记录一下日志Debug" name=hanyun
time="2020-03-09 17:23:00" level=info msg="| 200 | 2.9923ms | 127.0.0.1 | GET | / |"
当然了,这个日志库还可以将日志发送到elasticsearch,有兴趣的小伙伴可以尝试一下。
奉上代码,喜欢的小伙伴可以去自行下载
链接:https://pan.baidu.com/s/1fFsogIpPssm35CWV6H8m-g
提取码:xu7m