beego——日志處理


beego的日志處理是基於logs模塊搭建的,內置了一個變量BeeLogger,默認已經是logs.BeeLogger,初始化了console,也就是默認輸出到console。

使用入門

一般在程序中我們使用如下的方式進行輸出:

beego.Emergency("this is emergency")
beego.Alert("this is alert")
beego.Critical("this is critical")
beego.Error("this is error")
beego.Warning("this is warning")
beego.Notice("this is notice")
beego.Informational("this is informational")
beego.Debug("this is debug")

  

設置輸出

我們的程序往往期望把信息輸出到log中,現在設置輸出到文件很方便,如下所示:

beego.SetLogger("file", `{"filename":"logs/test.log"}`)

這個默認情況就會同時輸出到兩個地方,一個console,一個file,如果只想輸出到文件,就需要調用刪除操作:

beego.BeeLogger.DelLogger("console")

  

設置級別

日志的級別分為八個:

LevelEmergency
LevelAlert
LevelCritical
LevelError
LevelWarning
LevelNotice
LevelInformational
LevelDebug

級別依次降低,默認全部打印,但是一般我們在部署環境,可以通過設置界別設置日志級別:

beego.SetLevel(beego.LevelInformational)

  

輸出文件名和行號

日志默認不輸出調用的文件名的和行號,日過你期望調用的文件名和文件行號,可以如下設置:

beego.SetLogFuncCall(true)

開啟傳入參數true,關閉傳入參數false,默認是關閉的。

下面是一個完整示例:

func internalCalculationFunc(x, y int) (result int, err error) {
    beego.Debug("calculating z. x:", x, " y:", y)
    z := y
    switch {
    case x == 3:
        beego.Debug("x == 3")
        panic("Failure.")
    case y == 1:
        beego.Debug("y == 1")
        return 0, errors.New("Error!")
    case y == 2:
        beego.Debug("y == 2")
        z = x
    default:
        beego.Debug("default")
        z += x
    }
    retVal := z - 3
    beego.Debug("Returning ", retVal)

    return retVal, nil
}

func processInput(input inputData) {
    defer func() {
        if r := recover(); r != nil {
            beego.Error("Unexpected error occurred: ", r)
            outputs <- outputData{result: 0, error: true}
        }
    }()
    beego.Informational("Received input signal. x:", input.x, " y:", input.y)

    res, err := internalCalculationFunc(input.x, input.y)
    if err != nil {
        beego.Warning("Error in calculation:", err.Error())
    }

    beego.Informational("Returning result: ", res, " error: ", err)
    outputs <- outputData{result: res, error: err != nil}
}

func main() {
    inputs = make(chan inputData)
    outputs = make(chan outputData)
    criticalChan = make(chan int)
    beego.Informational("App started.")

    go consumeResults(outputs)
    beego.Informational("Started receiving results.")

    go generateInputs(inputs)
    beego.Informational("Started sending signals.")

    for {
        select {
        case input := <-inputs:
            processInput(input)
        case <-criticalChan:
            beego.Critical("Caught value from criticalChan: Go shut down.")
            panic("Shut down due to critical fault.")
        }
    }
}

  


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM