golang logrus日志按小时拆分(月删除)

一 log.go

package log

import (
    rotatelogs "github.com/lestrrat-go/file-rotatelogs"
    llog "github.com/sirupsen/logrus"
    "time"
    "uwb_pos/config"
)

func init() {
    path := config.LogPath
    writer, _ := rotatelogs.New(
        //path+".%Y%m%d%H%M",
        path+".%Y%m%d%H",
        rotatelogs.WithLinkName(path),
        rotatelogs.WithMaxAge(time.Duration(config.LogMaxAge)*time.Hour),
        rotatelogs.WithRotationTime(time.Duration(config.LogRotatTm)*time.Minute),
    )
    llog.SetOutput(writer)
    if config.LogLevel == 1{
        llog.SetLevel(llog.DebugLevel)
    }else if config.LogLevel == 2{
        llog.SetLevel(llog.InfoLevel)
    }else if config.LogLevel == 3{
        llog.SetLevel(llog.WarnLevel)
    }else if config.LogLevel == 4{
        llog.SetLevel(llog.ErrorLevel)
    }
    // no set , it will be info
}

二 main文件用.导入

package main

import (
    ...
    _ "uwb_pos/utils/log"
  ...

)

func main() {
    //tcp
   process()
}

三 process中使用日志

package udpserver

import (
    llog "github.com/sirupsen/logrus"
    "time"
)

func releaseLChan(){
    ...
    llog.Info("$$$end conn read" + time.Now().In(CstSh).Format("2006-01-02 15:04:05") + "$$$")
        ...
}

四 配置文件

package config

const(
  ...//logs
    LogPath = "./logs/log"
    LogMaxAge = 24*60   //hour
    LogRotatTm = 60   //min
    LogLevel = 2  //1 debug 2 info 3 warn 4 error
  ...

)

五 验证结果

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值