forked from panjjo/gosip
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathlogger.go
More file actions
63 lines (52 loc) · 1.45 KB
/
logger.go
File metadata and controls
63 lines (52 loc) · 1.45 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
package main
import (
"bytes"
"fmt"
"path/filepath"
"time"
rotatelogs "github.com/lestrrat-go/file-rotatelogs"
"github.com/rifflock/lfshook"
"github.com/sirupsen/logrus"
)
type LoggerFormatter struct{}
func (m *LoggerFormatter) Format(entry *logrus.Entry) ([]byte, error) {
var b *bytes.Buffer
if entry.Buffer != nil {
b = entry.Buffer
} else {
b = &bytes.Buffer{}
}
timestamp := entry.Time.Format("2006-01-02 15:04:05")
var newLog string
//HasCaller()为true才会有调用信息
if entry.HasCaller() {
fName := filepath.Base(entry.Caller.File)
newLog = fmt.Sprintf("[%s] [%s] [%s:%d %s] %s\n",
timestamp, entry.Level, fName, entry.Caller.Line, entry.Caller.Function, entry.Message)
} else {
newLog = fmt.Sprintf("[%s] [%s] %s\n", timestamp, entry.Level, entry.Message)
}
b.WriteString(newLog)
return b.Bytes(), nil
}
func initLog() {
filepaths := "./log/gosip.log"
writer, _ := rotatelogs.New(
filepaths+".%Y%m%d%H%M",
rotatelogs.WithLinkName(filepaths),
rotatelogs.WithMaxAge(time.Duration(604800)*time.Second),
rotatelogs.WithRotationTime(time.Duration(86400)*time.Second),
)
writeMap := lfshook.WriterMap{
logrus.InfoLevel: writer,
logrus.FatalLevel: writer,
logrus.DebugLevel: writer,
logrus.WarnLevel: writer,
logrus.ErrorLevel: writer,
logrus.PanicLevel: writer,
logrus.TraceLevel: writer,
}
logrus.SetReportCaller(true)
lfHook := lfshook.NewHook(writeMap, &LoggerFormatter{})
logrus.AddHook(lfHook)
}