zap.go 1.8 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667
  1. package core
  2. import (
  3. "fmt"
  4. "gin-vue-admin/global"
  5. "gin-vue-admin/utils"
  6. zaprotatelogs "github.com/lestrrat-go/file-rotatelogs"
  7. "go.uber.org/zap"
  8. "go.uber.org/zap/zapcore"
  9. "os"
  10. "time"
  11. )
  12. const (
  13. zapLogDir = "log"
  14. zapLogSoftLink = "latest_log"
  15. zapModule = "gin-vue-admin"
  16. )
  17. func init() {
  18. if global.GVA_CONFIG.Zap.File == "" {
  19. global.GVA_CONFIG.Zap.File = "DEBUG"
  20. }
  21. if ok, _ := utils.PathExists(zapLogDir); !ok {
  22. // directory not exist
  23. fmt.Println("create log directory")
  24. _ = os.Mkdir(zapLogDir, os.ModePerm)
  25. }
  26. var l = new(zapcore.Level)
  27. writeSyncer, err := getWriteSyncer()
  28. if err != nil {
  29. fmt.Printf("Get Write Syncer Failed err:%v", err.Error())
  30. return
  31. }
  32. encoder := getEncoderConfig()
  33. if err := l.UnmarshalText([]byte(global.GVA_CONFIG.Zap.Level)); err != nil {
  34. fmt.Printf("Unmarshal Level Failed err:%v", err.Error())
  35. return
  36. }
  37. core := zapcore.NewCore(encoder, writeSyncer, l)
  38. global.GVA_ZAP = zap.New(core, zap.AddCaller())
  39. }
  40. // getWriteSyncer zap logger中加入file-rotatelogs
  41. func getWriteSyncer() (zapcore.WriteSyncer, error) {
  42. fileWriter, err := zaprotatelogs.New(
  43. zapLogDir + string(os.PathSeparator) + "%Y-%m-%d-%H-%M.log",
  44. zaprotatelogs.WithLinkName(zapLogSoftLink),
  45. zaprotatelogs.WithMaxAge(7*24*time.Hour),
  46. zaprotatelogs.WithRotationTime(24*time.Hour),
  47. )
  48. return zapcore.AddSync(fileWriter), err
  49. }
  50. // getEncoderConfig 获取zapcore.Encoder
  51. func getEncoderConfig() zapcore.Encoder {
  52. encoderConfig := zap.NewProductionEncoderConfig()
  53. encoderConfig.EncodeTime = zapcore.ISO8601TimeEncoder
  54. encoderConfig.TimeKey = "time"
  55. encoderConfig.EncodeLevel = zapcore.CapitalLevelEncoder
  56. encoderConfig.EncodeDuration = zapcore.SecondsDurationEncoder
  57. encoderConfig.EncodeCaller = zapcore.ShortCallerEncoder
  58. return zapcore.NewConsoleEncoder(encoderConfig)
  59. }