/log

decorator for zap

Primary LanguageGo

installation

go get -u github.com/yuanyp8/log

User Case

stdout log

use the default Logger, write to stdout with the zap json format, and the default log output level is info

package main

import (
	"fmt"
	"github.com/yuanyp8/log"
	"os"
)

func defaultLogger() {
	defer log.Sync()

	log.Info("default stdout logger",
		log.String("level", "info"),
		log.String("app", "start ok"),
	)

	log.Debug("custom stdout logger",
		log.String("level", "debug"),
		log.String("app", "start ok"),
	)
}

func customStdLogger() {
	log.ResetDefault(log.New(os.Stdout, log.DebugLevel, log.WithCaller(false)))
	defer log.Sync()

	log.Debug("custom stdout logger",
		log.String("level", "debug"),
		log.String("app", "start ok"),
	)
}

func main() {
	defaultLogger()
	fmt.Println("--------------")
	customStdLogger()
}

output to file with rotate configuration

package main

import (
	"github.com/yuanyp8/log"
)

func defaultTeeLogger() {
	log.ResetDefault(log.DefaultTee())
	defer log.Sync()

	for i := 0; i < 20000; i++ {
		log.Info("rotate_logger:",
			log.String("app", "start ok"),
			log.Int("major version", 2),
		)
		log.Error("rotate_logger:",
			log.String("app", "crash"),
			log.Int("reason", -1),
		)
	}
}

func customTeeLogger() {
	tops := []log.TeeOption{
		{Filename: "custom/access.log",
			Ropt: log.RotateOptions{
				MaxSize:    2,
				MaxAge:     2,
				MaxBackups: 2,
				Compress:   false,
			},
			Lef: func(lvl log.Level) bool {
				return lvl <= log.InfoLevel
			},
		},
		{Filename: "custom/error.log",
			Ropt: log.RotateOptions{
				MaxSize:    2,
				MaxAge:     2,
				MaxBackups: 2,
				Compress:   false,
			},
			Lef: func(lvl log.Level) bool {
				return lvl > log.InfoLevel
			},
		},
	}

	logger := log.NewLoggerTeeWithRotate(tops)
	log.ResetDefault(logger)
	defer log.Sync()

	for i := 0; i < 20000; i++ {
		log.Info("rotate_logger:",
			log.String("app", "start ok"),
			log.Int("major version", 2),
		)
		log.Error("rotate_logger:",
			log.String("app", "crash"),
			log.Int("reason", -1),
		)
	}
}

func main() {
	defaultTeeLogger()
	customTeeLogger()
}