1.框架自带 gin框架自带日志记录功能,通过fmt.Fprint和fmt.Fprintf来记录日志信息,默认是将日志写到终端,可以通过gin.DefaultWriter来设置写入文件。
1.1 终端禁用颜色 1 gin.DisableConsoleColor()
1.2 只写入文件 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 func  main () "gin.log" )"/log" , func (context *gin.Context) "[gin-log] 日志测试使用 \n" )"[gin-log] Method: %v \n" , context.Request.Method)"[gin-log] Url: %v \n" , context.Request.URL)"[gin-log] Header: %v \n" , context.Request.Header)200 ,gin.H{"msg" :"success" })
请求效果 
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 in  "debug"  mode. Switch to "release"  mode in  production.export  GIN_MODE=releaselog                       --> go-use/practise.printOutFile.func1 (3 handlers)log " Not A;Brand" ;v="99" , "Chromium" ;v="90" , "Google Chrome" ;v="90" ] Sec-Ch-Ua-Mobile:[?0] Sec-Fetch-Dest:[document] Sec-Fetch-Mode:[navigate] Sec-Fetch-Site:[none] Sec-Fetch-User:[?1] Upgrade-Insecure-Requests:[1] User-Agent:[Mozilla/5.0 (Macintosh; Intel Mac OS X 10_15_7) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/90.0.4430.212 Safari/537.36]]"/log" 
1.3 同时写入文件和终端 如果想将日志同时写入文件和终端,只需要修改上述代码中的io.MultiWriter(f)即可,修改成以下内容
1 2 3 4 5 6 7 8 9 func  main () "gin.log" )
2.集成logrus logrus可能是 Go 目前最受欢迎的第三方日志库。目前Github Star = 17.9k,源码地址:https://github.com/sirupsen/logrus 
2.1 安装 1 go get -u github.com/sirupsen/logrus
2.2 设置属性 创建logrus_use.go文件,编写代码如下:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 package  mainimport  ("github.com/sirupsen/logrus" "os" "path" var  ("./log" "gin.log" var  LogInstance = logrus.New()func  init () if  err != nil  {panic (err)
2.3 使用 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 package  mainimport  ("github.com/gin-gonic/gin" "github.com/sirupsen/logrus" func  main () "/log" , func (context *gin.Context) "Method" : context.Request.Method,"Warning级别日志" )"param-name" : context.DefaultQuery("name" ,"" ),"Error级别日志" )if  context.DefaultQuery("key" ,"" ) == "1"  {"Host" : context.Request.Host,"Fatal级别日志" )"code" : context.Writer.Status(),"url"  : context.Request.URL.Path,"method"  : context.Request.Method,"info级别日志" )200 ,gin.H{"msg" :"success" })
2.4 日志内容 日志文件:log/gin.log
JSON格式 1 2 3 {"Method" :"GET" ,"level" :"warning" ,"msg" :"Warning级别日志" ,"time" :"2021-05-27T16:06:30+08:00" }"level" :"error" ,"msg" :"Error级别日志" ,"param-name" :"" ,"time" :"2021-05-27T16:06:30+08:00" }"code" :200 ,"level" :"info" ,"method" :"GET" ,"msg" :"info级别日志" ,"time" :"2021-05-27T16:06:30+08:00" ,"url" :"/log" }
Text格式 1 2 3 time="2021-05-27T16:35:16+08:00"  level=warning msg="Warning级别日志"  Method=GET"2021-05-27T16:35:16+08:00"  level=error msg="Error级别日志"  param-name="2021-05-27T16:35:16+08:00"  level=info msg="info级别日志"  code=200 method=GET url=/log 
3.压缩滚动 Lumberjack:https://github.com/natefinch/lumberjack 是一个Go包,用于将日志写入滚动文件。
3.1 安装 1 go get -u github.com/natefinch/lumberjack
3.2 导入 1 import  "github.com/natefinch/lumberjack" 
3.3 使用 修改logrus_use.go文件代码
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 package  mainimport  ("github.com/natefinch/lumberjack" "github.com/sirupsen/logrus" "path" var  ("./log" "gin.log" var  LogInstance = logrus.New()func  init () func  rolling (logFile string ) 1 ,3 ,1  ,true ,
main.go 代码 
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 package  mainimport  ("github.com/gin-gonic/gin" "github.com/sirupsen/logrus" "strings" func  main () "/log" , func (context *gin.Context) "Method" : context.Request.Method,"Warning级别日志" )"param-name" : context.DefaultQuery("name" ,"" ),"Error级别日志" )if  context.DefaultQuery("key" ,"" ) == "1"  {"Host" : context.Request.Host,"Fatal级别日志" )"code" : context.Writer.Status(),"url"  : context.Request.URL.Path,"context"  : strings.Repeat("测试" ,50000 ),"info级别日志" )200 ,gin.H{"msg" :"success" })
3.4 效果