You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
117 lines
2.4 KiB
117 lines
2.4 KiB
5 years ago
|
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 init() {
|
||
|
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.CapitalColorLevelEncoder,
|
||
|
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...)
|
||
|
}
|