婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > Golang logrus 日志包及日志切割的實現

Golang logrus 日志包及日志切割的實現

熱門標簽:烏魯木齊人工電銷機器人系統 賺地圖標注的錢犯法嗎 地圖標注測試 澳門防封電銷卡 智能電銷機器人營銷 濮陽自動外呼系統代理 廣東語音外呼系統供應商 福州鐵通自動外呼系統 長沙ai機器人電銷

本文主要介紹 Golang 中最佳日志解決方案,包括常用日志包logrus 的基本使用,如何結合file-rotatelogs 包實現日志文件的輪轉切割兩大話題。

Golang 關于日志處理有很多包可以使用,標準庫提供的 log 包功能比較少,不支持日志級別的精確控制,自定義添加日志字段等。在眾多的日志包中,更推薦使用第三方的 logrus 包,完全兼容自帶的 log 包。logrus 是目前 Github 上 star 數量最多的日志庫,logrus 功能強大,性能高效,而且具有高度靈活性,提供了自定義插件的功能。

很多開源項目,如 docker,prometheus,dejavuzhou/ginbro 等,都是用了 logrus 來記錄其日志。

logrus 特性

  • 完全兼容 golang 標準庫日志模塊:logrus 擁有六種日志級別:debug、info、warn、error、fatal 和 panic,這是 golang 標準庫日志模塊的 API 的超集。
  • logrus.Debug(“Useful debugging information.”)
  • logrus.Info(“Something noteworthy happened!”)
  • logrus.Warn(“You should probably take a look at this.”)
  • logrus.Error(“Something failed but I'm not quitting.”)
  • logrus.Fatal(“Bye.”) //log之后會調用os.Exit(1)
  • logrus.Panic(“I'm bailing.”) //log之后會panic()
  • 可擴展的 Hook 機制:允許使用者通過 hook 的方式將日志分發到任意地方,如本地文件系統、標準輸出、logstash、elasticsearch 或者 mq 等,或者通過 hook 定義日志內容和格式等。
  • 可選的日志輸出格式:logrus 內置了兩種日志格式,JSONFormatter 和 TextFormatter,如果這兩個格式不滿足需求,可以自己動手實現接口 Formatter 接口來定義自己的日志格式。
  • Field 機制:logrus 鼓勵通過 Field 機制進行精細化的、結構化的日志記錄,而不是通過冗長的消息來記錄日志。
  • logrus 是一個可插拔的、結構化的日志框架。
  • Entry: logrus.WithFields 會自動返回一個 *Entry,Entry里面的有些變量會被自動加上
  • time:entry被創建時的時間戳
  • msg:在調用.Info()等方法時被添加
  • level,當前日志級別

logrus 基本使用

package main

import (
  "os"

  "github.com/sirupsen/logrus"
  log "github.com/sirupsen/logrus"
)

var logger *logrus.Entry

func init() {
  // 設置日志格式為json格式
  log.SetFormatter(log.JSONFormatter{})
  log.SetOutput(os.Stdout)
  log.SetLevel(log.InfoLevel)
  logger = log.WithFields(log.Fields{"request_id": "123444", "user_ip": "127.0.0.1"})
}

func main() {
  logger.Info("hello, logrus....")
  logger.Info("hello, logrus1....")
  // log.WithFields(log.Fields{
  // "animal": "walrus",
  // "size":  10,
  // }).Info("A group of walrus emerges from the ocean")

  // log.WithFields(log.Fields{
  // "omg":  true,
  // "number": 122,
  // }).Warn("The group's number increased tremendously!")

  // log.WithFields(log.Fields{
  // "omg":  true,
  // "number": 100,
  // }).Fatal("The ice breaks!")
}

基于 logrus 和 file-rotatelogs 包實現日志切割

很多時候應用會將日志輸出到文件系統,對于訪問量大的應用來說日志的自動輪轉切割管理是個很重要的問題,如果應用不能妥善處理日志管理,那么會帶來很多不必要的維護開銷:外部工具切割日志、人工清理日志等手段確保不會將磁盤打滿。

file-rotatelogs: When you integrate this to to you app, it automatically write to logs that are rotated from within the app: No more disk-full alerts because you forgot to setup logrotate!

logrus 本身不支持日志輪轉切割功能,需要配合 file-rotatelogs 包來實現,防止日志打滿磁盤。file-rotatelogs 實現了 io.Writer 接口,并且提供了文件的切割功能,其實例可以作為 logrus 的目標輸出,兩者能無縫集成,這也是 file-rotatelogs 的設計初衷:

It's normally expected that this library is used with some other logging service, such as the built-in log library, or loggers such as github.com/lestrrat-go/apache-logformat.

示例代碼:

應用日志文件 /Users/opensource/test/go.log,每隔 1 分鐘輪轉一個新文件,保留最近 3 分鐘的日志文件,多余的自動清理掉。

package main

import (
 "time"

 rotatelogs "github.com/lestrrat-go/file-rotatelogs"
 log "github.com/sirupsen/logrus"
)

func init() {
 path := "/Users/opensource/test/go.log"
 /* 日志輪轉相關函數
 `WithLinkName` 為最新的日志建立軟連接
 `WithRotationTime` 設置日志分割的時間,隔多久分割一次
 WithMaxAge 和 WithRotationCount二者只能設置一個
  `WithMaxAge` 設置文件清理前的最長保存時間
  `WithRotationCount` 設置文件清理前最多保存的個數
 */
 // 下面配置日志每隔 1 分鐘輪轉一個新文件,保留最近 3 分鐘的日志文件,多余的自動清理掉。
 writer, _ := rotatelogs.New(
 path+".%Y%m%d%H%M",
 rotatelogs.WithLinkName(path),
 rotatelogs.WithMaxAge(time.Duration(180)*time.Second),
 rotatelogs.WithRotationTime(time.Duration(60)*time.Second),
 )
 log.SetOutput(writer)
 //log.SetFormatter(log.JSONFormatter{})
}

func main() {
 for {
 log.Info("hello, world!")
 time.Sleep(time.Duration(2) * time.Second)
 }
}

Golang 標準日志庫 log 使用

雖然 Golang 標準日志庫功能少,但是可以選擇性的了解下,下面為基本使用的代碼示例,比較簡單:

package main

import (
  "fmt"
  "log"
)

func init() {
  log.SetPrefix("【UserCenter】")              // 設置每行日志的前綴
  log.SetFlags(log.LstdFlags | log.Lshortfile | log.LUTC) // 設置日志的抬頭字段
}

func main() {
  log.Println("log...")
  log.Fatalln("Fatal Error...")
  fmt.Println("Not print!")
}

自定義日志輸出

package main

import (
  "io"
  "log"
  "os"
)

var (
  Info  *log.Logger
  Warning *log.Logger
  Error  *log.Logger
)

func init() {
  errFile, err := os.OpenFile("errors.log", os.O_CREATE|os.O_WRONLY|os.O_APPEND, 0666)
  if err != nil {
    log.Fatalln("打開日志文件失?。?, err)
  }

  Info = log.New(os.Stdout, "Info:", log.Ldate|log.Ltime|log.Lshortfile)
  Warning = log.New(os.Stdout, "Warning:", log.Ldate|log.Ltime|log.Lshortfile)
  Error = log.New(io.MultiWriter(os.Stderr, errFile), "Error:", log.Ldate|log.Ltime|log.Lshortfile)
}

func main() {
  Info.Println("Info log...")
  Warning.Printf("Warning log...")
  Error.Println("Error log...")
}

相關文檔

https://mojotv.cn/2018/12/27/golang-logrus-tutorial
https://github.com/lestrrat-go/file-rotatelogs
https://www.flysnow.org/2017/05/06/go-in-action-go-log.html

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。

您可能感興趣的文章:
  • golang有用的庫及工具 之 zap.Logger包的使用指南
  • golang elasticsearch Client的使用詳解
  • Golang的func參數及返回值操作
  • golang協程池模擬實現群發郵件功能
  • golang 比較浮點數的大小方式
  • 解決Golang中goroutine執行速度的問題
  • 解決golang結構體tag編譯錯誤的問題
  • golang日志包logger的用法詳解

標簽:貴陽 西雙版納 慶陽 廣西 太原 調研邀請 阿克蘇 德州

巨人網絡通訊聲明:本文標題《Golang logrus 日志包及日志切割的實現》,本文關鍵詞  Golang,logrus,日志,包,及,切割,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《Golang logrus 日志包及日志切割的實現》相關的同類信息!
  • 本頁收集關于Golang logrus 日志包及日志切割的實現的相關信息資訊供網民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    日韩美女主播在线视频一区二区三区 | 欧美tickling挠脚心丨vk| 国产91丝袜在线播放九色| 婷婷开心久久网| 亚洲成人免费看| 亚洲一区免费视频| 亚洲综合一区二区精品导航| 亚洲免费大片在线观看| 亚洲欧美另类小说视频| 亚洲欧洲日韩女同| 亚洲乱码中文字幕综合| 午夜一区二区三区视频| 午夜欧美在线一二页| 亚洲韩国一区二区三区| 午夜婷婷国产麻豆精品| 视频一区在线播放| 久久99最新地址| 国产成人免费9x9x人网站视频| 国产精品夜夜爽| 成人毛片视频在线观看| 99免费精品在线| 在线观看一区日韩| 欧美日韩三级视频| 欧美大片在线观看一区二区| 久久精品网站免费观看| 亚洲欧美另类久久久精品2019| 亚洲精品视频在线观看免费| 亚洲v中文字幕| 国产自产高清不卡| 成人国产一区二区三区精品| 欧美综合一区二区三区| 日韩亚洲欧美中文三级| 国产精品乱码一区二区三区软件| 国产精品全国免费观看高清| 午夜久久久久久电影| 国产成人在线影院| 欧美人动与zoxxxx乱| 久久精品欧美一区二区三区不卡 | 91黄色免费网站| 91精品国产乱| 国产精品毛片高清在线完整版| 香蕉加勒比综合久久| 国产精品88888| 在线观看国产一区二区| 日韩一级大片在线| 一区二区三区四区av| 国产精品69毛片高清亚洲| 欧美精品自拍偷拍| 中文字幕一区二区三区色视频| 亚洲国产精品综合小说图片区| 福利一区福利二区| 日韩三级.com| 性做久久久久久| av激情综合网| 国产亚洲欧美色| 午夜精品免费在线观看| 不卡一区中文字幕| 久久久久久9999| 午夜精品成人在线| 91亚洲男人天堂| 欧美激情一区二区三区在线| 秋霞电影网一区二区| 欧美综合天天夜夜久久| 成人免费一区二区三区在线观看| 精品一区二区影视| 日韩欧美一区二区视频| 午夜影视日本亚洲欧洲精品| 在线精品观看国产| 亚洲另类中文字| 99这里只有久久精品视频| 国产精品网站一区| 播五月开心婷婷综合| 中文字幕不卡在线| 国产v日产∨综合v精品视频| 国产欧美日韩在线视频| 久久精品国产第一区二区三区| 欧美精三区欧美精三区| 亚洲高清免费视频| 欧美精品免费视频| 日韩av电影免费观看高清完整版| 8x8x8国产精品| 免费成人美女在线观看.| 日韩一区二区三区免费看 | 不卡一二三区首页| 日韩理论电影院| 色婷婷av一区二区三区之一色屋| 亚洲免费观看高清| 欧美在线视频全部完| 亚洲国产成人va在线观看天堂| 欧美日韩激情一区二区三区| 亚洲高清免费一级二级三级| 欧美福利视频一区| 久久超碰97人人做人人爱| 精品精品国产高清a毛片牛牛| 国产麻豆日韩欧美久久| 国产精品久久久久毛片软件| 色婷婷av一区二区三区软件| 亚洲成人资源网| 日韩一区二区视频在线观看| 国产一区二区三区久久悠悠色av| 国产精品三级久久久久三级| 在线看日本不卡| 精品一区二区三区日韩| 最新国产成人在线观看| 欧美日本一区二区三区四区| 久久精品99国产精品日本| 国产精品乱人伦一区二区| 欧美日韩三级视频| 精品一区中文字幕| 亚洲综合免费观看高清完整版| 欧美一区二区不卡视频| av网站一区二区三区| 五月婷婷综合激情| 中文字幕免费一区| 欧美人动与zoxxxx乱| 成人app网站| 美女精品一区二区| 国产精品传媒视频| 精品精品国产高清a毛片牛牛| 日本韩国欧美在线| 国产成人av一区二区三区在线观看| 亚洲欧美日韩国产综合| 久久久久亚洲综合| 日本久久一区二区| 不卡在线视频中文字幕| 久久99精品国产麻豆不卡| 亚洲综合一二区| 亚洲欧洲成人自拍| 国产日韩欧美一区二区三区乱码| 欧美美女喷水视频| 色噜噜狠狠成人网p站| 成人a免费在线看| 极品销魂美女一区二区三区| 亚洲1区2区3区视频| 亚洲理论在线观看| 国产精品久久久久四虎| 久久综合给合久久狠狠狠97色69| 欧美精品免费视频| 欧美日本一区二区在线观看| 日本丰满少妇一区二区三区| 成人免费毛片app| 国产成人精品在线看| 激情综合一区二区三区| 美女在线一区二区| 日韩1区2区日韩1区2区| 水野朝阳av一区二区三区| 亚洲成人在线观看视频| 亚洲欧美韩国综合色| 亚洲欧洲精品天堂一级| 亚洲欧美在线另类| 中文字幕亚洲精品在线观看| 国产精品色噜噜| 亚洲天堂中文字幕| 亚洲精品美国一| 亚欧色一区w666天堂| 午夜精品视频在线观看| 亚洲成人av电影| 日本不卡一区二区| 久久精品国产亚洲一区二区三区| 日韩av网站免费在线| 美女网站视频久久| 国产自产v一区二区三区c| 国产福利一区二区三区视频在线 | 欧美电影一区二区| 欧美一级视频精品观看| 欧美大尺度电影在线| 久久久国产午夜精品| 欧美国产一区二区| 亚洲欧洲精品一区二区三区| 亚洲免费观看高清完整版在线| 亚洲午夜久久久久久久久电影院 | 91网页版在线| 欧亚一区二区三区| 欧美精品在线观看播放| 久久综合五月天婷婷伊人| 中文字幕精品—区二区四季| 亚洲伊人伊色伊影伊综合网| 日本在线不卡视频一二三区| 国内精品伊人久久久久影院对白| 国产99久久久国产精品潘金| 在线观看亚洲成人| 久久久久久麻豆| 亚洲免费观看高清完整版在线观看 | 国产精品久久久久久久久免费樱桃| 中文字幕一区在线观看视频| 亚洲国产中文字幕| 久久国产尿小便嘘嘘尿| 91美女片黄在线观看91美女| 欧美高清视频不卡网| 中文字幕免费不卡| 五月综合激情网| 成人免费看的视频| 在线播放中文字幕一区| 亚洲国产精华液网站w| 婷婷成人综合网| 91亚洲精品久久久蜜桃| 久久精品欧美一区二区三区麻豆| 一区二区三区色| 国产精品123| 91精品国模一区二区三区|