[go]日志库小例子

Posted iiiiiher

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了[go]日志库小例子相关的知识,希望对你有一定的参考价值。

输出日志

//输出日志到console
msg := fmt.Sprintf(format, args...) //format里的坑  args解出的数据相匹配
fmt.Fprintf(os.Stdout, "%s
", msg)


//输出日志到文件
file, _ := os.OpenFile("/tmp/test.log", os.O_CREATE|os.O_APPEND|os.O_WRONLY, 0755)
fmt.Fprintf(file, "name: %s
", "maotai")

异步写日志

//将日志写入chan
select {
case f.LogDataChan <- logData:
default:
}

//从chan中去除日志写到文件
for logData := range f.LogDataChan {
    fmt.Fprintf(file, "%s %s (%s:%s:%d) %s
", logData.TimeStr, logData.LevelStr, logData.Filename, logData.FuncName, logData.LineNo, logData.Message)
}

以上是关于[go]日志库小例子的主要内容,如果未能解决你的问题,请参考以下文章

Go开源宝藏十分强大的日志库 logrus

[Go] 通过 17 个简短代码片段,切底弄懂 channel 基础

解决go: go.mod file not found in current directory or any parent directory; see ‘go help modules‘(代码片段

argparse 代码片段只打印部分日志

常用python日期日志获取内容循环的代码片段

你知道的Go切片扩容机制可能是错的