代码拉取完成,页面将自动刷新
package logger
import (
"errors"
"path"
"strings"
"time"
"gitee.com/pangxianfei/multiapp/config"
rotatelogs "github.com/lestrrat-go/file-rotatelogs"
"github.com/rifflock/lfshook"
"github.com/sirupsen/logrus"
"gitee.com/pangxianfei/multiapp/log/formatter"
)
type Daily struct {
}
func (daily *Daily) Handle(channel string) (logrus.Hook, error) {
var hook logrus.Hook
logPath := config.GetString(channel + ".path")
if logPath == "" {
return hook, errors.New("error log path")
}
ext := path.Ext(logPath)
logPath = strings.ReplaceAll(logPath, ext, "")
writer, err := rotatelogs.New(
logPath+"-%Y-%m-%d"+ext,
rotatelogs.WithRotationTime(time.Duration(24)*time.Hour),
rotatelogs.WithRotationCount(uint(config.GetInt(channel+".days"))),
)
if err != nil {
return hook, errors.New("Config local file system for logger error: " + err.Error())
}
levels := getLevels(config.GetString(channel + ".level"))
writerMap := lfshook.WriterMap{}
for _, level := range levels {
writerMap[level] = writer
}
return lfshook.NewHook(
writerMap,
&formatter.General{},
), nil
}
此处可能存在不合适展示的内容,页面不予展示。您可通过相关编辑功能自查并修改。
如您确认内容无涉及 不当用语 / 纯广告导流 / 暴力 / 低俗色情 / 侵权 / 盗版 / 虚假 / 无价值内容或违法国家有关法律法规的内容,可点击提交进行申诉,我们将尽快为您处理。