2021-06-07 17:22:07 +08:00
|
|
|
|
package logger
|
2021-03-24 17:18:39 +08:00
|
|
|
|
|
|
|
|
|
|
import (
|
|
|
|
|
|
"fmt"
|
2021-07-28 18:03:19 +08:00
|
|
|
|
"mayfly-go/base/config"
|
|
|
|
|
|
"mayfly-go/base/global"
|
|
|
|
|
|
"os"
|
2021-03-24 17:18:39 +08:00
|
|
|
|
"strings"
|
|
|
|
|
|
"time"
|
|
|
|
|
|
|
|
|
|
|
|
"github.com/sirupsen/logrus"
|
|
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
|
|
var Log = logrus.New()
|
|
|
|
|
|
|
|
|
|
|
|
func init() {
|
|
|
|
|
|
Log.SetFormatter(new(LogFormatter))
|
|
|
|
|
|
Log.SetReportCaller(true)
|
2021-07-28 18:03:19 +08:00
|
|
|
|
|
|
|
|
|
|
logConf := config.Conf.Log
|
|
|
|
|
|
// 如果不存在日志配置信息,则默认debug级别
|
|
|
|
|
|
if logConf == nil {
|
|
|
|
|
|
Log.SetLevel(logrus.DebugLevel)
|
|
|
|
|
|
return
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
// 根据配置文件设置日志级别
|
|
|
|
|
|
if level := logConf.Level; level != "" {
|
|
|
|
|
|
l, err := logrus.ParseLevel(level)
|
|
|
|
|
|
if err != nil {
|
|
|
|
|
|
panic(fmt.Sprintf("日志级别不存在: %s", level))
|
|
|
|
|
|
}
|
|
|
|
|
|
Log.SetLevel(l)
|
|
|
|
|
|
} else {
|
|
|
|
|
|
Log.SetLevel(logrus.DebugLevel)
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
if logFile := logConf.File; logFile != nil {
|
|
|
|
|
|
//写入文件
|
|
|
|
|
|
file, err := os.OpenFile(logFile.GetFilename(), os.O_CREATE|os.O_APPEND|os.O_WRONLY, os.ModeAppend|0666)
|
|
|
|
|
|
if err != nil {
|
|
|
|
|
|
panic(fmt.Sprintf("创建日志文件失败: %s", err.Error()))
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
Log.Out = file
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
global.Log = Log
|
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()))
|
2022-01-12 16:00:31 +08:00
|
|
|
|
// 如果存在调用信息,记录方法信息及行号
|
2021-04-16 15:10:07 +08:00
|
|
|
|
if caller := entry.Caller; caller != nil {
|
2022-01-12 16:00:31 +08:00
|
|
|
|
logMsg = logMsg + fmt.Sprintf(" [%s:%d]", caller.Function, 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
|
|
|
|
|
|
}
|