修改zerolog使log输出的文件名可以在goland里自动定位--技巧

Posted xdao

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了修改zerolog使log输出的文件名可以在goland里自动定位--技巧相关的知识,希望对你有一定的参考价值。

如何自动定位文件

最近发现goland会自动识别输出的文件或者url,但是有时候又识别不出来,折腾了一下,发现原来要求文件路径或url两边要有空格

改造zerolog

既然如此,那么让我们来改造一下zerolog,跟踪了一下代码,发现原来写都在io.writer里,于是复制出这个文件,然后增加了一个格式化代码
技术分享图片
完整的代码在github

增加颜色输出

可以使用这个库,github.com/mattn/go-colorable,输出到它的colorable.NewColorableStdout里面去

测试结果

package main

import (
    "github.com/mattn/go-colorable"
    "github.com/rs/zerolog"
    "github.com/dwdcth/consoleEx"
)

func main() {
    out := consoleEx.ConsoleWriterEx{Out: colorable.NewColorableStdout()}
    zerolog.CallerSkipFrameCount = 2  //这里根据实际,另外获取的是Msg调用处的文件路径和行号
    logger := zerolog.New(out).With().Caller().Timestamp().Logger()

    logger.Info().Msg("info")
    logger.Debug().Msg("debug")
}

技术分享图片

以上是关于修改zerolog使log输出的文件名可以在goland里自动定位--技巧的主要内容,如果未能解决你的问题,请参考以下文章

python logging 定向不输出到屏幕?

如何让log4j日志只输出错误信息

python的logging模块格式化输出到控制台、文件

保存命令行输出信息到log的方法(ubunut下和arm-linux下有效)

Confluence 6 修改日志文件的目标位置

bash 输出log文件