mirror of
https://github.com/HDT3213/godis.git
synced 2025-10-07 01:32:56 +08:00
use io.LimitedReader; fix logger prefix concurrent
This commit is contained in:
8
aof.go
8
aof.go
@@ -5,7 +5,6 @@ import (
|
|||||||
"github.com/hdt3213/godis/datastruct/dict"
|
"github.com/hdt3213/godis/datastruct/dict"
|
||||||
"github.com/hdt3213/godis/datastruct/lock"
|
"github.com/hdt3213/godis/datastruct/lock"
|
||||||
"github.com/hdt3213/godis/lib/logger"
|
"github.com/hdt3213/godis/lib/logger"
|
||||||
"github.com/hdt3213/godis/lib/utils"
|
|
||||||
"github.com/hdt3213/godis/redis/parser"
|
"github.com/hdt3213/godis/redis/parser"
|
||||||
"github.com/hdt3213/godis/redis/reply"
|
"github.com/hdt3213/godis/redis/reply"
|
||||||
"io"
|
"io"
|
||||||
@@ -78,7 +77,12 @@ func (db *DB) loadAof(maxBytes int) {
|
|||||||
}
|
}
|
||||||
defer file.Close()
|
defer file.Close()
|
||||||
|
|
||||||
reader := utils.NewLimitedReader(file, maxBytes)
|
var reader io.Reader
|
||||||
|
if maxBytes > 0 {
|
||||||
|
reader = io.LimitReader(file, int64(maxBytes))
|
||||||
|
} else {
|
||||||
|
reader = file
|
||||||
|
}
|
||||||
ch := parser.ParseStream(reader)
|
ch := parser.ParseStream(reader)
|
||||||
for p := range ch {
|
for p := range ch {
|
||||||
if p.Err != nil {
|
if p.Err != nil {
|
||||||
|
@@ -7,6 +7,7 @@ import (
|
|||||||
"os"
|
"os"
|
||||||
"path/filepath"
|
"path/filepath"
|
||||||
"runtime"
|
"runtime"
|
||||||
|
"sync"
|
||||||
"time"
|
"time"
|
||||||
)
|
)
|
||||||
|
|
||||||
@@ -23,6 +24,7 @@ var (
|
|||||||
defaultPrefix = ""
|
defaultPrefix = ""
|
||||||
defaultCallerDepth = 2
|
defaultCallerDepth = 2
|
||||||
logger *log.Logger
|
logger *log.Logger
|
||||||
|
mu sync.Mutex
|
||||||
logPrefix = ""
|
logPrefix = ""
|
||||||
levelFlags = []string{"DEBUG", "INFO", "WARN", "ERROR", "FATAL"}
|
levelFlags = []string{"DEBUG", "INFO", "WARN", "ERROR", "FATAL"}
|
||||||
)
|
)
|
||||||
@@ -75,30 +77,40 @@ func setPrefix(level logLevel) {
|
|||||||
|
|
||||||
// Debug prints debug log
|
// Debug prints debug log
|
||||||
func Debug(v ...interface{}) {
|
func Debug(v ...interface{}) {
|
||||||
|
mu.Lock()
|
||||||
|
defer mu.Unlock()
|
||||||
setPrefix(DEBUG)
|
setPrefix(DEBUG)
|
||||||
logger.Println(v...)
|
logger.Println(v...)
|
||||||
}
|
}
|
||||||
|
|
||||||
// Info prints normal log
|
// Info prints normal log
|
||||||
func Info(v ...interface{}) {
|
func Info(v ...interface{}) {
|
||||||
|
mu.Lock()
|
||||||
|
defer mu.Unlock()
|
||||||
setPrefix(INFO)
|
setPrefix(INFO)
|
||||||
logger.Println(v...)
|
logger.Println(v...)
|
||||||
}
|
}
|
||||||
|
|
||||||
// Warn prints warning log
|
// Warn prints warning log
|
||||||
func Warn(v ...interface{}) {
|
func Warn(v ...interface{}) {
|
||||||
|
mu.Lock()
|
||||||
|
defer mu.Unlock()
|
||||||
setPrefix(WARNING)
|
setPrefix(WARNING)
|
||||||
logger.Println(v...)
|
logger.Println(v...)
|
||||||
}
|
}
|
||||||
|
|
||||||
// Error prints error log
|
// Error prints error log
|
||||||
func Error(v ...interface{}) {
|
func Error(v ...interface{}) {
|
||||||
|
mu.Lock()
|
||||||
|
defer mu.Unlock()
|
||||||
setPrefix(ERROR)
|
setPrefix(ERROR)
|
||||||
logger.Println(v...)
|
logger.Println(v...)
|
||||||
}
|
}
|
||||||
|
|
||||||
// Fatal prints error log then stop the program
|
// Fatal prints error log then stop the program
|
||||||
func Fatal(v ...interface{}) {
|
func Fatal(v ...interface{}) {
|
||||||
|
mu.Lock()
|
||||||
|
defer mu.Unlock()
|
||||||
setPrefix(FATAL)
|
setPrefix(FATAL)
|
||||||
logger.Fatalln(v...)
|
logger.Fatalln(v...)
|
||||||
}
|
}
|
||||||
|
@@ -1,37 +0,0 @@
|
|||||||
package utils
|
|
||||||
|
|
||||||
import (
|
|
||||||
"errors"
|
|
||||||
"io"
|
|
||||||
)
|
|
||||||
|
|
||||||
// LimitedReader implements io.Reader, but you can only read the given number of bytes
|
|
||||||
type LimitedReader struct {
|
|
||||||
src io.Reader
|
|
||||||
n int
|
|
||||||
limit int
|
|
||||||
}
|
|
||||||
|
|
||||||
// NewLimitedReader wraps an io.Reader to LimitedReader
|
|
||||||
func NewLimitedReader(src io.Reader, limit int) *LimitedReader {
|
|
||||||
return &LimitedReader{
|
|
||||||
src: src,
|
|
||||||
limit: limit,
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// Read reads up to len(p) bytes into p. if meets EOF from src or reach limit, it returns EOF
|
|
||||||
func (r *LimitedReader) Read(p []byte) (n int, err error) {
|
|
||||||
if r.src == nil {
|
|
||||||
return 0, errors.New("no data source")
|
|
||||||
}
|
|
||||||
if r.limit > 0 && r.n >= r.limit {
|
|
||||||
return 0, io.EOF
|
|
||||||
}
|
|
||||||
n, err = r.src.Read(p)
|
|
||||||
if err != nil {
|
|
||||||
return n, err
|
|
||||||
}
|
|
||||||
r.n += n
|
|
||||||
return
|
|
||||||
}
|
|
Reference in New Issue
Block a user