mirror of
https://github.com/HDT3213/godis.git
synced 2025-09-27 13:12:19 +08:00

wip: raft does not care about migrating wip: optimize code wip: raft election wip wip: fix raft leader missing log entries wip fix a dead lock batch set slot route wip: raft persist wip refactor cluster suite remove relay rename relay2 refactor: allow customizing client factory test raft refactor re-balance avoid errors caused by inconsistent status on follower nodes during raft commits test raft election
139 lines
2.5 KiB
Go
139 lines
2.5 KiB
Go
package logger
|
|
|
|
import (
|
|
"fmt"
|
|
"io"
|
|
"log"
|
|
"os"
|
|
"path/filepath"
|
|
"runtime"
|
|
"sync"
|
|
"time"
|
|
)
|
|
|
|
// Settings stores config for logger
|
|
type Settings struct {
|
|
Path string `yaml:"path"`
|
|
Name string `yaml:"name"`
|
|
Ext string `yaml:"ext"`
|
|
TimeFormat string `yaml:"time-format"`
|
|
}
|
|
|
|
var (
|
|
logFile *os.File
|
|
defaultPrefix = ""
|
|
defaultCallerDepth = 2
|
|
logger *log.Logger
|
|
mu sync.Mutex
|
|
logPrefix = ""
|
|
levelFlags = []string{"DEBUG", "INFO", "WARN", "ERROR", "FATAL"}
|
|
)
|
|
|
|
type logLevel int
|
|
|
|
// log levels
|
|
const (
|
|
DEBUG logLevel = iota
|
|
INFO
|
|
WARNING
|
|
ERROR
|
|
FATAL
|
|
)
|
|
|
|
const flags = log.LstdFlags
|
|
|
|
func init() {
|
|
logger = log.New(os.Stdout, defaultPrefix, flags)
|
|
}
|
|
|
|
// Setup initializes logger
|
|
func Setup(settings *Settings) {
|
|
var err error
|
|
dir := settings.Path
|
|
fileName := fmt.Sprintf("%s-%s.%s",
|
|
settings.Name,
|
|
time.Now().Format(settings.TimeFormat),
|
|
settings.Ext)
|
|
|
|
logFile, err = mustOpen(fileName, dir)
|
|
if err != nil {
|
|
log.Fatalf("logging.Join err: %s", err)
|
|
}
|
|
|
|
mw := io.MultiWriter(os.Stdout, logFile)
|
|
logger = log.New(mw, defaultPrefix, flags)
|
|
}
|
|
|
|
func setPrefix(level logLevel) {
|
|
_, file, line, ok := runtime.Caller(defaultCallerDepth)
|
|
if ok {
|
|
logPrefix = fmt.Sprintf("[%s][%s:%d] ", levelFlags[level], filepath.Base(file), line)
|
|
} else {
|
|
logPrefix = fmt.Sprintf("[%s] ", levelFlags[level])
|
|
}
|
|
|
|
logger.SetPrefix(logPrefix)
|
|
}
|
|
|
|
// Debug prints debug log
|
|
func Debug(v ...interface{}) {
|
|
mu.Lock()
|
|
defer mu.Unlock()
|
|
setPrefix(DEBUG)
|
|
logger.Println(v...)
|
|
}
|
|
|
|
func Debugf(format string, v ...interface{}) {
|
|
mu.Lock()
|
|
defer mu.Unlock()
|
|
setPrefix(DEBUG)
|
|
logger.Println(fmt.Sprintf(format, v...))
|
|
}
|
|
|
|
// Info prints normal log
|
|
func Info(v ...interface{}) {
|
|
mu.Lock()
|
|
defer mu.Unlock()
|
|
setPrefix(INFO)
|
|
logger.Println(v...)
|
|
}
|
|
|
|
// Infof prints normal log
|
|
func Infof(format string, v ...interface{}) {
|
|
mu.Lock()
|
|
defer mu.Unlock()
|
|
setPrefix(INFO)
|
|
logger.Println(fmt.Sprintf(format, v...))
|
|
}
|
|
|
|
// Warn prints warning log
|
|
func Warn(v ...interface{}) {
|
|
mu.Lock()
|
|
defer mu.Unlock()
|
|
setPrefix(WARNING)
|
|
logger.Println(v...)
|
|
}
|
|
|
|
// Error prints error log
|
|
func Error(v ...interface{}) {
|
|
mu.Lock()
|
|
defer mu.Unlock()
|
|
setPrefix(ERROR)
|
|
logger.Println(v...)
|
|
}
|
|
|
|
func Errorf(format string, v ...interface{}) {
|
|
mu.Lock()
|
|
defer mu.Unlock()
|
|
setPrefix(ERROR)
|
|
logger.Println(fmt.Sprintf(format, v...))
|
|
}
|
|
|
|
// Fatal prints error log then stop the program
|
|
func Fatal(v ...interface{}) {
|
|
mu.Lock()
|
|
defer mu.Unlock()
|
|
setPrefix(FATAL)
|
|
logger.Fatalln(v...)
|
|
}
|