go语言logrus使用,以及进行日志切割


package initial

import (
	"bytes"
	"fmt"
	"io"
	"os"
	"path/filepath"

	"github.com/astaxie/beego"
	log "github.com/sirupsen/logrus"
	lumberjack "gopkg.in/natefinch/lumberjack.v2"
)

type MyFormatter struct{}

func (m *MyFormatter) Format(entry *log.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

	if entry.HasCaller() {
		fName := filepath.Base(entry.Caller.File)
		newLog = fmt.Sprintf("[%s] [%s] [%s:%d]: %s\n",
			timestamp, entry.Level, fName, entry.Caller.Line, entry.Message)
	} else {
		newLog = fmt.Sprintf("[%s] [%s] %s\n", timestamp, entry.Level, entry.Message)
	}

	b.WriteString(newLog)
	return b.Bytes(), nil
}

func InitLog() {

	log.SetFormatter(&MyFormatter{})
	// 0 panic
	// 2 error
	// 4 Info
	// 5 debug
	logLevel := beego.AppConfig.DefaultInt("logLevel", 5)
	logPath := beego.AppConfig.DefaultString("logPath", "/var/log/harbor-imgsvr/harbor-imgsvr.log")

	log.SetLevel(log.Level(logLevel))
	log.SetReportCaller(true)
	logger := &lumberjack.Logger{
		LocalTime:  true,
		Filename:   logPath,
		MaxSize:    20, // 一个文件最大为20M
		MaxBackups: 5,  // 最多同时保存5份文件
		MaxAge:     30, // 一个文件最多同时存在30天
		Compress:   false,
	}
	writers := []io.Writer{
		logger,
		os.Stdout,
	}
	fileAndStdoutWriter := io.MultiWriter(writers...) //
	log.SetOutput(fileAndStdoutWriter)
}
  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值