Files
mayfly-go/base/logger/logger.go

47 lines
1.2 KiB
Go
Raw Normal View History

package logger
2021-03-24 17:18:39 +08:00
import (
"fmt"
"strings"
"time"
"github.com/sirupsen/logrus"
)
var Log = logrus.New()
func init() {
// customFormatter := new(logrus.TextFormatter)
// customFormatter.TimestampFormat = "2006-01-02 15:04:05.000"
// customFormatter.FullTimestamp = true
Log.SetFormatter(new(LogFormatter))
Log.SetReportCaller(true)
Log.SetLevel(logrus.DebugLevel)
2021-03-24 17:18:39 +08:00
}
type LogFormatter struct{}
func (l *LogFormatter) Format(entry *logrus.Entry) ([]byte, error) {
timestamp := time.Now().Local().Format("2006-01-02 15:04:05.000")
level := entry.Level
logMsg := fmt.Sprintf("%s [%s]", timestamp, strings.ToUpper(level.String()))
// 如果存在调用信息且为error级别以上记录文件及行号
2021-04-16 15:10:07 +08:00
if caller := entry.Caller; caller != nil {
var fp string
// 全路径切割,只获取项目相关路径,
// 即/Users/hml/Desktop/project/go/mayfly-go/server/test.go只获取/server/test.go
ps := strings.Split(caller.File, "mayfly-go/")
if len(ps) >= 2 {
fp = ps[1]
2021-04-16 15:10:07 +08:00
} else {
fp = ps[0]
2021-04-16 15:10:07 +08:00
}
logMsg = logMsg + fmt.Sprintf(" [%s:%d]", fp, caller.Line)
2021-03-24 17:18:39 +08:00
}
for k, v := range entry.Data {
logMsg = logMsg + fmt.Sprintf(" [%s=%v]", k, v)
}
logMsg = logMsg + fmt.Sprintf(" : %s\n", entry.Message)
return []byte(logMsg), nil
}