go seelog配置文件详细解释

之前写过一篇博客,但是理解未深入,也是博取众长,今天再详细记录一遍,这个第三方库用来管理日志很方面
以下为seelog.xml的配置文件,对配置文件的使用进行了详细说明

<seelog type="asynctimer" asyncinterval="1000000" minlevel="debug" maxlevel="error">
    <outputs formatid="main">
        <console/>
        <!-- 输出到文件,且不同于终端的日志格式 -->
        <!-- <splitter> 用于细分<outputs>日志格式,内部支持:file(文件), rollingfile(滚动文件,自动清除过期),buffered(日志写到内存再写到文件), smtp(发送日志到邮件), con(网络转发) -->
        <splitter formatid="main">
            <!-- <rollingfile>滚动文件(定期清除过期日志)formatid: 指定日志格式; type="size" 按大小; maxsize: 单日志文件最大大小; maxrools: 最大文件数 -->
            <rollingfile type="size" filename="logs/all.log" maxsize="10485760" maxrolls="150"/><!-- 输出到指定位置 -->
            <file path="log.log"/> <!-- 输出到默认位置 -->
        </splitter>
        <!-- <filter>用于单独处理某级别日志过滤日志,把级别是error的通过邮件smtp方式发送出去(一般会发给相应的运维人员) -->
        <filter levels="debug">
            <rollingfile formatid="main" type="size" filename="logs/debug.log" maxsize="10485760" maxrolls="150"/>
        </filter>
        <filter levels="info">
            <rollingfile formatid="main" type="size" filename="logs/info.log" maxsize="10485760" maxrolls="150"/>
        </filter>
        <filter levels="warn">
            <rollingfile formatid="main" type="size" filename="logs/warn.log" maxsize="10485760" maxrolls="150"/>
        </filter>
        <filter levels="error">
            <rollingfile formatid="main" type="size" filename="logs/error.log" maxsize="10485760" maxrolls="150"/>
        </filter>
    </outputs>

    <formats>
        <!-- 设置格式 -->
        <!-- 设置格式,输出UTC日期 UTC时间 - 缩写版大写日志级别 - 相对于应用程序运行目录的调用者路径 - 日志记录器被调用时的行号 - 消息文本(最后换行) -->
        <format id="main" format="%UTCDate %UTCTime - [%LEV] - %RelFile - l%Line - %Msg%n"/>
        <format id="format1" format="%Date(2006 Jan 02/3:04:05.000000000 PM MST) [%Level] %Msg%n"/>
    </formats>
</seelog>

//main函数的程序如下

package main

import (
	"fmt"
	"github.com/cihub/seelog"
	"os"
	"path"
	"path/filepath"
	"time"
)

func main() {
	defer seelog.Flush()
	num := 0
	for {
		time.Sleep(time.Second * 1)
		num++
		seelog.Debug("调试消息", num)
		seelog.Info("日志消息", num)
		seelog.Error("错误消息", num)
		seelog.Warn("报警消息", num)
	}
}
//初始化,init()函数会在每个包完成初始化后自动执行,并且执行优先级比main函数高
func init() {
	SetupLogger()
}

//日志设置
func SetupLogger() {
	println("test i am hungry")
	defer func() {
		seelog.Flush()
	}()
	baseDir, err := filepath.Abs(filepath.Dir(os.Args[0])) //获取程序路径
	CurrentDir := baseDir
	logger, err := seelog.LoggerFromConfigAsFile(path.Join(CurrentDir, "seelog.xml")) //读取配置,创建记录器
	if err != nil {
		fmt.Println(err)
		return
	}

	if err != nil {
		panic("日志配置文件读取错误")
	}
	seelog.ReplaceLogger(logger)
}

运行后的文件输出如下:
在这里插入图片描述

在这里插入代码片
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值