zap.go 2.8 KB
Newer Older
1 2 3 4 5 6 7 8 9 10 11 12 13
package core

import (
	"fmt"
	"gin-vue-admin/global"
	"gin-vue-admin/utils"
	zaprotatelogs "github.com/lestrrat-go/file-rotatelogs"
	"go.uber.org/zap"
	"go.uber.org/zap/zapcore"
	"os"
	"time"
)

14 15 16 17
var (
	err    error
	level zapcore.Level
	writer zapcore.WriteSyncer
18 19 20
)

func init() {
21 22 23
	if ok, _ := utils.PathExists(global.GVA_CONFIG.Zap.Director); !ok { // 判断是否有logs文件夹
		fmt.Println("create logs directory") // directory not exist
		_ = os.Mkdir(global.GVA_CONFIG.Zap.Director, os.ModePerm)
24
	}
25 26 27 28 29 30 31 32 33 34 35 36

	switch global.GVA_CONFIG.Zap.Level {// 初始化配置文件的Level
	case "debug":
		level = zap.DebugLevel
	case "info":
		level = zap.InfoLevel
	case "warn":
		level = zap.WarnLevel
	case "error":
		level = zap.ErrorLevel
	default:
		level = zap.InfoLevel
37
	}
38 39

	writer, err = getWriteSyncer() // 使用file-rotatelogs进行日志分割
40 41 42 43
	if err != nil {
		fmt.Printf("Get Write Syncer Failed err:%v", err.Error())
		return
	}
44 45 46 47 48 49

	if level == zap.DebugLevel || level == zap.ErrorLevel {
		global.GVA_ZAP = zap.New(getEncoderCore(), zap.AddStacktrace(level))
		if global.GVA_CONFIG.Zap.ShowLine {
			global.GVA_ZAP.WithOptions(zap.AddCaller())
		}
50 51
		return
	}
52 53 54 55 56
	global.GVA_ZAP = zap.New(getEncoderCore())
	if global.GVA_CONFIG.Zap.ShowLine {
		global.GVA_ZAP.WithOptions(zap.AddCaller())
	}

57 58 59 60 61
}

// getWriteSyncer zap logger中加入file-rotatelogs
func getWriteSyncer() (zapcore.WriteSyncer, error) {
	fileWriter, err := zaprotatelogs.New(
62 63
		global.GVA_CONFIG.Zap.Director+string(os.PathSeparator)+"%Y-%m-%d-%H-%M.log",
		zaprotatelogs.WithLinkName(global.GVA_CONFIG.Zap.LinkName),
64 65 66
		zaprotatelogs.WithMaxAge(7*24*time.Hour),
		zaprotatelogs.WithRotationTime(24*time.Hour),
	)
67 68 69
	if global.GVA_CONFIG.Zap.LogInConsole {
		return zapcore.NewMultiWriteSyncer(zapcore.AddSync(os.Stdout), zapcore.AddSync(fileWriter)), err
	}
70 71 72
	return zapcore.AddSync(fileWriter), err
}

73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88
// getEncoderConfig 获取zapcore.EncoderConfig
func getEncoderConfig() (config zapcore.EncoderConfig) {
	config = zapcore.EncoderConfig{
		MessageKey:     "message",
		LevelKey:       "level",
		TimeKey:        "time",
		NameKey:        "logger",
		CallerKey:      "caller",
		StacktraceKey:  "stacktrace",
		LineEnding:     zapcore.DefaultLineEnding,
		EncodeLevel:    zapcore.CapitalColorLevelEncoder,
		EncodeTime:     CustomTimeEncoder,
		EncodeDuration: zapcore.SecondsDurationEncoder,
		EncodeCaller:   zapcore.FullCallerEncoder,
	}
	return config
89 90
}

91 92 93 94
// getEncoder 获取zapcore.Encoder
func getEncoder() zapcore.Encoder {
	return zapcore.NewConsoleEncoder(getEncoderConfig())
}
95

96 97 98 99
// getEncoderCore 获取Encoder的zapcore.Core
func getEncoderCore() (core zapcore.Core) {
	return zapcore.NewCore(getEncoder(), writer, level)
}
100

101 102 103 104
// 自定义日志输出时间格式
func CustomTimeEncoder(t time.Time, enc zapcore.PrimitiveArrayEncoder) {
	enc.AppendString(t.Format(global.GVA_CONFIG.Zap.Prefix+"2006/01/02 - 15:04:05.000"))
}