package log import ( "os" "strings" "go.uber.org/zap" "go.uber.org/zap/zapcore" ) var ( formatLogger *zap.SugaredLogger levelMap = map[string]zapcore.Level{ "debug": zapcore.DebugLevel, "info": zapcore.InfoLevel, "warn": zapcore.WarnLevel, "error": zapcore.ErrorLevel, "panic": zapcore.PanicLevel, "fatal": zapcore.FatalLevel, } ) func InitLog() { logger := newLogger("debug") formatLogger = logger.Sugar() } func newLogger(level string) *zap.Logger { core := newCore(level) return zap.New(core, zap.AddCaller(), zap.AddCallerSkip(1), zap.Development(), ) } func newCore(level string) zapcore.Core { encoderConfig := zapcore.EncoderConfig{ TimeKey: "time", LevelKey: "level", NameKey: "logger", CallerKey: "line", MessageKey: "msg", StacktraceKey: "stacktrace", LineEnding: zapcore.DefaultLineEnding, EncodeLevel: zapcore.CapitalLevelEncoder, EncodeTime: zapcore.ISO8601TimeEncoder, EncodeDuration: zapcore.SecondsDurationEncoder, // EncodeCaller: zapcore.ShortCallerEncoder, EncodeName: zapcore.FullNameEncoder, } return zapcore.NewCore( zapcore.NewConsoleEncoder(encoderConfig), zapcore.NewMultiWriteSyncer(zapcore.AddSync(os.Stdout)), zap.NewAtomicLevelAt(getLoggerLevel(level)), ) } func getLoggerLevel(lvl string) zapcore.Level { if level, ok := levelMap[strings.ToLower(lvl)]; ok { return level } return zapcore.InfoLevel } func Debug(args ...interface{}) { formatLogger.Debug(args...) } func Debugf(template string, args ...interface{}) { formatLogger.Debugf(template, args...) } func Info(args ...interface{}) { formatLogger.Info(args...) } func Infof(template string, args ...interface{}) { formatLogger.Infof(template, args...) } func Warn(args ...interface{}) { formatLogger.Warn(args...) } func Warnf(template string, args ...interface{}) { formatLogger.Warnf(template, args...) } func Error(args ...interface{}) { formatLogger.Error(args...) } func Errorf(template string, args ...interface{}) { formatLogger.Errorf(template, args...) } func Panic(args ...interface{}) { formatLogger.Panic(args...) } func Panicf(template string, args ...interface{}) { formatLogger.Panicf(template, args...) } func Fatal(args ...interface{}) { formatLogger.Fatal(args...) } func Fatalf(template string, args ...interface{}) { formatLogger.Fatalf(template, args...) } func Println(args ...interface{}) { formatLogger.Debug(args...) }