zoukankan      html  css  js  c++  java
  • Golang学习笔记----日志log

    一、log日志包

    log支持并发操作。其结构定义如下

    1type Logger struct {
    2    mu sync.Mutex     // ensures atomic writes; protects the following fields
    3    prefix string     // prefix to write at beginning of each line // ⽇志⾏前缀
    4    flag int          // properties // ⽇志打印格式标志,⽤于指定每⾏⽇志的打印格式
    5    out io.Writer     // destination for output // ⽤于指定⽇志输出位置,理论上可以是任务地⽅,只要实现了io.Writer接⼝就⾏
    6    buf []byte        // for accumulating text to write // ⽇志内容
    7}

    log基本日志格式

    1Ldate       = 1 << iota     //  形如  2009/01/23  的⽇期
    2Ltime                       //  形如  01:23:23            的时间
    3Lmicroseconds               //  形如  01:23:23.123123         的时间
    4Llongfile                   //  全路径⽂件名和⾏号:  /a/b/c/d.go:23  
    5Lshortfile                  //  ⽂件名和⾏号: d.go:23 
    6LstdFlags   = Ldate | Ltime //  ⽇期和时间

    (1)Golang's log模块主要提供了3类接口。分别是 “Print 、Panic 、Fatal ”,对每一类接口其提供了3中调用方式,分别是 "Xxxx 、Xxxxln 、Xxxxf",基本和fmt中的相关函数类似。

    • log.Print:打印日志,和fmt.包没什么区别,只是加上了上面的日志格式
    • log.Fatal :,会先将日志内容打印到标准输出,接着调用系统的os.exit(1) 接口,退出程序并返回状态 1 。但是有一点需要注意,由于是直接调用系统接口退出,defer函数不会被调用。
    • log.Panic:该函数把日志内容刷到标准错误后调用 panic 函数,

     

    Demo

    package main
    
    import (
        "fmt"
        "log"
    )
    
    //fatal
    func testDeferfatal() {
        defer func() {
            fmt.Println("--first--")
        }()
        log.Fatalln("test for defer Fatal")
    }
    
    //panic
    func testDeferpanic() {
        defer func() {
            fmt.Println("--first--")
            if err := recover(); err != nil {
                fmt.Println(err)
            }
        }()
        log.Panicln("test for defer Panic")
        defer func() {
            fmt.Println("--second--")
        }()
    
    }
    func main() {
        arr := []int{2, 3}
    
        log.Print("Print array ", arr, "
    ")
        log.Println("Println array", arr)
        log.Printf("Printf array with item [%d,%d]
    ", arr[0], arr[1])
    
        testDeferpanic()
    
        //testDeferfatal()
    }

    (2)你也可以自定义Logger类型
    log.Logger提供了一个New方法用来创建对象
    函数原型

    func New(out io.Writer, prefix string, flag int) *Logger

    ①输出位置out,是一个io.Writer对象,该对象可以是一个文件也可以是实现了该接口的对象。通常我们可以用这个来指定日志输出到哪个文件
    ②prefix 我们在前面已经看到,就是在日志内容前面的东西。我们可以将其置为 "[Info]" 、 "[Warning]"等来帮助区分日志级别。
    ③flags 是一个选项,显示日志开头的东西,可选的值见前面所述

     

    Demo

    import (
        "log"
        "os"
    )
    
    func main() {
        fileName := "Info_First.log" //路径+文件名
        logFile, err := os.Create(fileName)
        defer logFile.Close()
        if err != nil {
            log.Fatalln("open file error")
        }
        debugLog := log.New(logFile, "[Info]", log.Llongfile)
        debugLog.Println("A Info message here")
        debugLog.SetPrefix("[Debug]")
        debugLog.Println("A Debug Message here ")
    }

    参考链接:

    https://developer.aliyun.com/article/682076

  • 相关阅读:
    mongodb 记录
    php保存文件
    调用AngularJS的API
    angular修改数据
    大小写转换
    使用Properties类动态加载配置文件里的内容
    org.apache.commons.cli.Options
    Google guava和Apache commons
    orc格式文件
    shell的awk命令使用
  • 原文地址:https://www.cnblogs.com/saryli/p/13533979.html
Copyright © 2011-2022 走看看