簡單介紹Go語言常用的打log方式

roc_guo發表於2022-11-16
文章介紹了3種常用的打log的方式,並賦上了註解

先寫上注意事項,三種方法建議分開測,因為可能在第一種的Fatal會終止執行,Fatal和Panic和Print的區別在於,Fatal會儲存日誌並終止程式,Panic會儲存日誌並丟出異常終止程式,Print會儲存日誌但是程式繼續

main.go

package main
 
import (
    "log"
    "bytes"
    "fmt"
    "os"
"github.com/astaxie/beego/logs"
)
 
func main() {
 
    //1.日誌寫入一段快取裡
    var buf bytes.Buffer
    logger := log.New(&buf, "logger: ", log.Llongfile)//三個引數對應輸出物件,字首,檔名然後整合成字首
    logger.Print("Hello, log file!") //實際log資訊
    fmt.Println(&buf)
 
    //2.日誌寫入一段檔案裡,執行完重新整理工程,會有檔案debug.log開啟來看
    fileName := "debug.log"  //在工程路徑下和src同級,也可以寫絕對路徑,不過要注意轉義符
    logFile,err  := os.Create(fileName)  //建立該檔案,返回控制程式碼
    defer logFile.Close()      //確保檔案在該函式執行完以後關閉
    if err != nil {  
        log.Fatalln("open file error !")  
    }  
 
    //庫裡的log包不存在級別,只有Print,Fatal,Panic三種,想要7種級別,可以用syslog包或者框架
    debugLog := log.New(logFile,"",log.Llongfile)  
    debugLog.Print("找到一個低階bug,低階別的日誌報告,執行debug記錄後繼續執行")
    debugLog.Fatal("發現一個嚴重bug,日誌已記錄,程式在此終止")
    debugLog.Panic("哎呀,我沒有被執行,好慘")
 
    //3.使用beego框架的log包進行log處理 ,對應7種級別
    logInstance:=logs.GetLogger()
    logInstance.Println("this is a message of http")
    //an official log.Logger with prefix ORM
    logs.GetLogger("ORM").Println("this is a message of orm")
    logs.Debug("my book is bought in the year of ", 2016)
    logs.Info("this %s cat is %v years old", "yellow", 3)
    logs.Warn("json is a type of kv like", map[string]int{"key": 2016})
    logs.Error(1024, "is a very", "good game")
    logs.Critical("oh,crash")
    logs.Notice("fuck")
    logs.Alert("alert")
    logs.Emergency("emergency")
 
}
第二種

main.go

package main
 
import (
    "os"
    "log"
)
 
 
 
func main() {
    file, err := os.OpenFile("./testLog/test.log",  os.O_CREATE | os.O_WRONLY | os.O_APPEND,os.ModePerm)
    if err != nil {
        log.Fatalln(err)
    }
    logger := log.New(file, "", log.LstdFlags|log.Llongfile)
    logger.Println("日誌1.")
    logger.Println("日誌23")
}


來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/69901823/viewspace-2923581/,如需轉載,請註明出處,否則將追究法律責任。

相關文章