123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156 |
- package log
- import (
- "os"
- "time"
- "github.com/natefinch/lumberjack"
- "go.uber.org/zap"
- "go.uber.org/zap/zapcore"
- )
- const CallerSkipNum = 1
- var (
- s *zap.SugaredLogger
- )
- func zapEncoderConfig() zapcore.EncoderConfig {
- return zapcore.EncoderConfig{
- TimeKey: "timestamp",
- LevelKey: "level",
- NameKey: "logger",
- CallerKey: "caller",
- MessageKey: "message",
- StacktraceKey: "stacktrace",
- LineEnding: "\n",
- EncodeLevel: zapcore.LowercaseLevelEncoder,
- EncodeTime: func(t time.Time, e zapcore.PrimitiveArrayEncoder) {
- e.AppendString(t.Format("2006-01-02 15:04:05"))
- },
- EncodeDuration: zapcore.SecondsDurationEncoder,
- EncodeCaller: zapcore.FullCallerEncoder,
- }
- }
- func init() {
- config := zap.Config{
- Level: zap.NewAtomicLevelAt(zapcore.DebugLevel),
- Encoding: "json",
- EncoderConfig: zapEncoderConfig(),
- InitialFields: map[string]interface{}{"service": "pink"},
- OutputPaths: []string{"stdout"},
- ErrorOutputPaths: []string{"stdout"},
- }
- logger, err := config.Build(zap.AddCallerSkip(CallerSkipNum))
- if err != nil {
- panic(err)
- }
- s = logger.Sugar()
- }
- func NewLoggerSugar(serviceName, logFile string, level int32) error {
- hook := &lumberjack.Logger{
- Filename: logFile,
- MaxSize: 128,
- MaxAge: 7,
- MaxBackups: 30,
- Compress: false,
- }
- fileWriter := zapcore.AddSync(hook)
- writes := []zapcore.WriteSyncer{fileWriter}
- if zapcore.Level(level) == zapcore.DebugLevel {
- writes = append(writes, zapcore.AddSync(os.Stdout))
- }
- lowPriority := zap.LevelEnablerFunc(func(lev zapcore.Level) bool {
- return lev >= zap.DebugLevel
- })
- zcore := zapcore.NewCore(
- zapcore.NewJSONEncoder(zapEncoderConfig()),
- zapcore.NewMultiWriteSyncer(writes...),
- lowPriority,
- )
- fields := zap.Fields(zap.String("service_name", serviceName))
- logger := zap.New(zcore, zap.AddCallerSkip(CallerSkipNum), fields)
- s = logger.Sugar()
- return nil
- }
- func Debug(args ...interface{}) {
- s.Debug(args)
- }
- func Info(args ...interface{}) {
- s.Info(args)
- }
- func Warn(args ...interface{}) {
- s.Warn(args)
- }
- func Error(args ...interface{}) {
- s.Error(args)
- }
- func DPanic(args ...interface{}) {
- s.DPanic(args)
- }
- func Panic(args ...interface{}) {
- s.Panic(args)
- }
- func Fatal(args ...interface{}) {
- s.Fatal(args)
- }
- func Debugf(template string, args ...interface{}) {
- s.Debugf(template, args...)
- }
- func Infof(template string, args ...interface{}) {
- s.Infof(template, args...)
- }
- func Warnf(template string, args ...interface{}) {
- s.Warnf(template, args...)
- }
- func Errorf(template string, args ...interface{}) {
- s.Errorf(template, args...)
- }
- func DPanicf(template string, args ...interface{}) {
- s.DPanicf(template, args...)
- }
- func Panicf(template string, args ...interface{}) {
- s.Panicf(template, args...)
- }
- func Fatalf(template string, args ...interface{}) {
- s.Fatalf(template, args...)
- }
|