校园春色亚洲色图_亚洲视频分类_中文字幕精品一区二区精品_麻豆一区区三区四区产品精品蜜桃

主頁 > 知識庫 > golang log4go的日志輸出優化詳解

golang log4go的日志輸出優化詳解

熱門標簽:惠州電銷防封電話卡 建造者2地圖標注 汕頭小型外呼系統 濱州自動電銷機器人排名 阿里云ai電話機器人 黃岡人工智能電銷機器人哪個好 鄭州亮點科技用的什么外呼系統 浙江高頻外呼系統多少錢一個月 釘釘有地圖標注功能嗎

前言

在go語言中,自身已經集成了一定log模塊,開發者可以使用go語言自身的log包(import “log”) 。也有不少對自身log的開源封裝。對于一些簡單的開發,自身的log模塊就已經足夠應付。但是對一些大型,復雜的開發,log需要分門別類的輸出,或者通過網絡進行輸出,自身log模塊將難以應對。

當前也有一些比較重量級的log模塊,比如logrus,可以實現比較復雜的功能。這里介紹一個輕量級的log模塊——log4go

最近又看了一些golang的日志包和相關的文章,仔細閱讀了go 1.9.2系統提供的log和go-log,產生了對log4go的日志輸出進行優化的想法。

結構化與multiwriter

log使用multiwriter支持多個日志輸出,用 Mutex 加鎖解決多線程日志輸出的沖突。log4go 則采用結構化編程用 channel 傳遞 LogRecord 日志記錄。

原來以為 channel 的效率比較高……其實這是一個偽命題。channel 是一個全局加鎖的隊列,可以用來加鎖,但效率比較低。因為它多了傳遞數據、協調順序處理、timout等功能,并不僅僅是加鎖。跟Mutex不是一回事兒。

log4go 將屏幕日志輸出 termlog 放在了結構里,這帶來一個小問題。當我們用log4go調試小程序時,運行的太快,termlog 的 goroutine 還沒有運行起來,程序就退出了。結果屏幕上沒有顯示日志。這個問題只能通過在 Close() 時加延時,等待 goroutine 啟動來解決。然后還要檢查 channel ……

func (f *Filter) Close() {
 if f.closed {
  return
 }
 // sleep at most one second and let go routine running
 // drain the log channel before closing
 for i := 10; i > 0; i-- {
  // Must call Sleep here, otherwise, may panic send on closed channel
  time.Sleep(100 * time.Millisecond)
  if len(f.rec) = 0 {
   break
  }
 }
 // block write channel
 f.closed = true
 defer f.LogWriter.Close()
 close(f.rec)
 if len(f.rec) = 0 {
  return
 }
 // drain the log channel and write driect
 for rec := range f.rec {
  f.LogWrite(rec)
 }
}

log直接將格式化日志信息輸出到屏幕,簡單多了。

試著兼顧兩者,在 log4go 中增加了 writer,直接輸出到屏幕。擬將FileLog,SocketLog作為backend,仍然放在結構里。這樣,調試小程序和生產程序可以使用同一個日志庫。實測效率略有降低。不知道 windows 下的 ColorLog 如何,以后再說。

在log4go中可以通過調用 SetOutput(nil) ,使out = nil 來關閉屏幕輸出。

Determine caller func - it's expensive

這句話注釋在 log 源文件中,log4go也要調用runtime.Caller(skip int)函數來獲取源文件名和行號。它是昂貴的——消耗了CPU。建議在生產環境中關閉,log.SetSkip(-1) 。如果要對log4go進行封裝,設置 log.SetSkip(log.GetSkip()+1)

format優化

其實,這才是文章的主題。

日志輸出避免不了打印日期和時間,linux 環境下還要打印微秒,說不定還要打印時區。log4go的pattlog.go就是完成這些工作的。

  • 有一個1秒更新一次的cache機制。很漂亮。
  • 大量使用字符串格式化函數——fmt.Sprintf。
  • 返回字符串。而writer一般支持的是[]byte。多做一次轉換。
  • 每次都bytes.Splite講format字符串以%字符分解成[][]byte。

在log里邊自備了一個cheap的itoa函數。

// Cheap integer to fixed-width decimal ASCII. Give a negative width to avoid zero-padding.
func itoa(buf *[]byte, i int, wid int) {
 // Assemble decimal in reverse order.
 var b [20]byte
 bp := len(b) - 1
 for i >= 10 || wid > 1 {
  wid--
  q := i / 10
  b[bp] = byte('0' + i - q*10)
  bp--
  i = q
 }
 // i  10
 b[bp] = byte('0' + i)
 *buf = append(*buf, b[bp:]...)
}

用這個函數替換日期和時間的字符串格式化函數。用[]byte代替string。

優化前,log4go 的 benchmark。

BenchmarkFormatLogRecord-4    300000    4480 ns/op
BenchmarkConsoleLog-4     1000000    1748 ns/op
BenchmarkConsoleNotLogged-4    20000000    97.5 ns/op
BenchmarkConsoleUtilLog-4     300000    3496 ns/op
BenchmarkConsoleUtilNotLog-4   20000000    104 ns/op

優化后:

BenchmarkFormatLogRecord-4  1000000    1443 ns/op
BenchmarkConsoleLog-4   2000000    982 ns/op
BenchmarkConsoleUtilLog-4   500000    3242 ns/op
BenchmarkConsoleUtilNotLog-4 30000000    48.4 ns/op

格式化日期時間所花的時間是原來的1/3。

打印無格式化信息所花的時間是原來的1/2。

BenchmarkConsoleUtilLog調用了runtime.Caller,格式化信息,且新增了輸出信息到屏幕的時間。

字符串格式化——比較昂貴。

總結

以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作具有一定的參考學習價值,如果有疑問大家可以留言交流,謝謝大家對腳本之家的支持。

您可能感興趣的文章:
  • Golang報“import cycle not allowed”錯誤的2種解決方法
  • Golang常見錯誤之值拷貝和for循環中的單一變量詳解
  • Golang巧用defer進行錯誤處理的方法
  • golang新手們容易犯的3個錯誤總結
  • Golang中重復錯誤處理的優化方法

標簽:滄州 晉中 阿壩 東營 瀘州 駐馬店 泰安 昭通

巨人網絡通訊聲明:本文標題《golang log4go的日志輸出優化詳解》,本文關鍵詞  golang,log4go,的,日志,輸出,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《golang log4go的日志輸出優化詳解》相關的同類信息!
  • 本頁收集關于golang log4go的日志輸出優化詳解的相關信息資訊供網民參考!
  • 推薦文章
    校园春色亚洲色图_亚洲视频分类_中文字幕精品一区二区精品_麻豆一区区三区四区产品精品蜜桃
    欧美色手机在线观看| 欧美女孩性生活视频| 国产91丝袜在线18| 男人的j进女人的j一区| 天堂在线一区二区| 日本亚洲电影天堂| 免费人成在线不卡| 日本美女一区二区| 久久精品国产亚洲一区二区三区| 色老汉av一区二区三区| 欧美色涩在线第一页| 欧美精品欧美精品系列| 久久久精品人体av艺术| 日韩一区中文字幕| 日本在线不卡一区| 国产精品夜夜爽| 欧美在线一区二区三区| 91麻豆精品国产自产在线观看一区| 日韩精品一区二区三区在线观看| 久久综合色播五月| 亚洲黄色免费网站| 激情五月婷婷综合网| 色综合婷婷久久| 日韩欧美精品在线视频| 国产精品理论在线观看| 亚洲九九爱视频| 国产中文一区二区三区| 色伊人久久综合中文字幕| 精品少妇一区二区三区在线播放| 亚洲国产精品成人综合| 日韩专区中文字幕一区二区| 国产精品18久久久久久久久| 日本精品一级二级| 国产精品热久久久久夜色精品三区 | 成人免费小视频| 日产国产欧美视频一区精品| 国产精品一卡二卡在线观看| 欧美本精品男人aⅴ天堂| 亚洲妇熟xx妇色黄| 99精品桃花视频在线观看| 精品国产免费视频| 久久成人av少妇免费| 5566中文字幕一区二区电影| 99精品久久99久久久久| 日韩三级伦理片妻子的秘密按摩| 91精品欧美久久久久久动漫| 天天综合色天天综合| 成人av片在线观看| 2023国产精品| 久久超级碰视频| 欧美高清视频一二三区| 一区二区视频在线看| 国产98色在线|日韩| 国内精品国产成人国产三级粉色| 91精品国产综合久久香蕉麻豆| 国产精品卡一卡二| 风间由美中文字幕在线看视频国产欧美| 国产蜜臀av在线一区二区三区| 亚洲美女电影在线| 色天天综合色天天久久| 亚洲视频狠狠干| 欧美综合久久久| 亚欧色一区w666天堂| 色哟哟一区二区| 夜色激情一区二区| 欧美性生活影院| 天天综合日日夜夜精品| 69精品人人人人| 免播放器亚洲一区| 国产午夜亚洲精品理论片色戒| 成人一二三区视频| 尤物av一区二区| 欧美视频在线观看一区| 蜜桃av噜噜一区| 精品国产一区二区精华| 成人av在线一区二区三区| 亚洲欧美日韩精品久久久久| 欧美一区二区精美| 99re这里都是精品| 日本女人一区二区三区| 国产日产欧美精品一区二区三区| 国内精品在线播放| 蜜臀av一区二区在线免费观看 | 亚洲激情图片一区| 欧美网站大全在线观看| 日韩国产在线观看| 国产无人区一区二区三区| 欧美亚洲国产一区在线观看网站| 免费精品视频最新在线| 亚洲日本在线a| 日韩精品一区二区三区三区免费 | 日本韩国一区二区三区| 日韩精品一二区| 亚洲精品欧美在线| 久久美女艺术照精彩视频福利播放 | 久久成人羞羞网站| 亚洲你懂的在线视频| 欧美日韩亚洲综合一区| 国产一区二区在线观看免费| 国产精品久久午夜夜伦鲁鲁| 在线观看视频一区二区欧美日韩| 国产一区二区三区在线观看精品| 日韩一区二区在线看| 日本aⅴ亚洲精品中文乱码| 久久久久久久久久电影| 99视频超级精品| 亚洲精品乱码久久久久久久久| 911精品国产一区二区在线| 97精品视频在线观看自产线路二| 欧美成人女星排行榜| 国产综合久久久久久鬼色| 亚洲视频网在线直播| 欧美调教femdomvk| 日本韩国一区二区三区| 欧美大片国产精品| 色国产精品一区在线观看| 国产乱子轮精品视频| 一区二区三区影院| 国产日韩精品久久久| 精品美女在线播放| 日韩三级av在线播放| 欧美va亚洲va| 久久久91精品国产一区二区精品| 成人免费电影视频| 99久久99久久综合| 亚洲第一电影网| 欧美一区永久视频免费观看| 成人午夜精品在线| 男人的j进女人的j一区| 国产高清久久久| 国产露脸91国语对白| 亚洲福利一区二区| 韩国成人精品a∨在线观看| 国产欧美日韩在线| 亚洲国产成人一区二区三区| 亚洲精品在线一区二区| 国产欧美日韩卡一| 久久九九全国免费| 亚洲精品免费在线| 亚洲欧美日韩成人高清在线一区| 捆绑调教美女网站视频一区| 久久精品免费看| 亚洲美女少妇撒尿| 依依成人综合视频| 一区二区三区鲁丝不卡| 欧美国产禁国产网站cc| 在线综合视频播放| 中文字幕av一区二区三区高| 亚洲裸体在线观看| 精品国产91乱码一区二区三区 | 94色蜜桃网一区二区三区| 欧美一二区视频| 欧美色图天堂网| 欧美日产国产精品| 国产日韩欧美麻豆| 日本成人在线视频网站| 91日韩在线专区| 国产色一区二区| 亚洲国产一区二区三区| 久久99精品久久久久久久久久久久 | 国产一区二区不卡| 天天色天天操综合| 色婷婷综合五月| 一本一道综合狠狠老| 国产高清在线精品| 92国产精品观看| 成人av在线网站| 精品日韩欧美在线| 伊人夜夜躁av伊人久久| 久久精品久久久精品美女| 91国偷自产一区二区开放时间| 国产亚洲视频系列| 亚洲免费观看高清在线观看| 成人av电影免费在线播放| 91精品国产手机| 精品少妇一区二区三区| 人人爽香蕉精品| 91丝袜国产在线播放| 精品国产三级a在线观看| 日韩黄色免费电影| 一本色道a无线码一区v| 夜夜嗨av一区二区三区| 欧洲视频一区二区| 国产精品网站一区| 成人激情免费电影网址| 亚洲图片另类小说| 丝袜a∨在线一区二区三区不卡| 日本午夜一区二区| 在线视频欧美精品| 国产精品少妇自拍| 欧美色爱综合网| 亚洲图片自拍偷拍| 欧美一区二区观看视频| 久久成人综合网| 精品国产免费人成电影在线观看四季| 亚洲h动漫在线| 亚洲国产经典视频| 欧美体内she精高潮| 自拍偷拍亚洲激情| 91网址在线看|