日志文件

默认情况下,日志文件名称以当前时间日期命名,格式为 YYYY-MM-DD.log,我们可以使用 SetFile 方法来设置文件名称的格式,并且文件名称格式支持 时间管理-gtime 时间格式 。简单示例:

  1. package main
  2. import (
  3. "context"
  4. "github.com/gogf/gf/v2/frame/g"
  5. "github.com/gogf/gf/v2/os/gfile"
  6. "github.com/gogf/gf/v2/os/glog"
  7. )
  8. // 设置日志等级
  9. func main() {
  10. ctx := context.TODO()
  11. path := "./glog"
  12. glog.SetPath(path)
  13. glog.SetStdoutPrint(false)
  14. // 使用默认文件名称格式
  15. glog.Print(ctx, "标准文件名称格式,使用当前时间时期")
  16. // 通过SetFile设置文件名称格式
  17. glog.SetFile("stdout.log")
  18. glog.Print(ctx, "设置日志输出文件名称格式为同一个文件")
  19. // 链式操作设置文件名称格式
  20. glog.File("stderr.log").Print(ctx, "支持链式操作")
  21. glog.File("error-{Ymd}.log").Print(ctx, "文件名称支持带gtime日期格式")
  22. glog.File("access-{Ymd}.log").Print(ctx, "文件名称支持带gtime日期格式")
  23. list, err := gfile.ScanDir(path, "*")
  24. g.Dump(err)
  25. g.Dump(list)
  26. }

执行后,输出结果为:

  1. <nil>
  2. [
  3. "C:\hailaz\test\glog\2021-12-31.log",
  4. "C:\hailaz\test\glog\access-20211231.log",
  5. "C:\hailaz\test\glog\error-20211231.log",
  6. "C:\hailaz\test\glog\stderr.log",
  7. "C:\hailaz\test\glog\stdout.log",
  8. ]

可以看到,文件名称格式中如果需要使用 gtime 时间格式,格式内容需要使用 {xxx} 包含起来。该示例中也使用到了 链式操作 的特性,具体请看后续说明。

日志目录

默认情况下, glog 将会输出日志内容到标准输出,我们可以通过 SetPath 方法设置日志输出的目录路径,这样日志内容将会写入到日志文件中,并且由于其内部使用了 gfpool 文件指针池,文件写入的效率相当优秀。简单示例:

  1. package main
  2. import (
  3. "context"
  4. "github.com/gogf/gf/v2/frame/g"
  5. "github.com/gogf/gf/v2/os/gfile"
  6. "github.com/gogf/gf/v2/os/glog"
  7. )
  8. // 设置日志等级
  9. func main() {
  10. ctx := context.TODO()
  11. path := "./glog"
  12. glog.SetPath(path)
  13. glog.Print(ctx, "日志内容")
  14. list, err := gfile.ScanDir(path, "*")
  15. g.Dump(err)
  16. g.Dump(list)
  17. }

执行后,输出内容为:

  1. 2021-12-31 11:32:16.742 日志内容
  2. <nil>
  3. [
  4. "C:\hailaz\test\glog\2021-12-31.log",
  5. ]

当通过 SetPath 设置日志的输出目录,如果目录不存在时,将会递归创建该目录路径。可以看到,执行 Println 之后,在 /tmp 下创建了日志目录 glog,并且在其下生成了日志文件。同时,我们也可以看见日志内容不仅输出到了文件,默认情况下也输出到了终端,我们可以通过 SetStdoutPrint(false) 方法来关闭终端的日志输出,这样日志内容仅会输出到日志文件中。