亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > Golang > 正文

golang log4go的日志輸出優化詳解

2020-04-01 18:59:59
字體:
來源:轉載
供稿:網友

前言

在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/opBenchmarkConsoleLog-4     1000000    1748 ns/opBenchmarkConsoleNotLogged-4    20000000    97.5 ns/opBenchmarkConsoleUtilLog-4     300000    3496 ns/opBenchmarkConsoleUtilNotLog-4   20000000    104 ns/op

優化后:

BenchmarkFormatLogRecord-4  1000000    1443 ns/opBenchmarkConsoleLog-4   2000000    982 ns/opBenchmarkConsoleUtilLog-4   500000    3242 ns/opBenchmarkConsoleUtilNotLog-4 30000000    48.4 ns/op

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

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

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

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

總結

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


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
亚洲经典中文字幕| 色无极亚洲影院| 国产精品入口免费视频一| 欧美福利视频在线观看| 久久精品视频99| 97人洗澡人人免费公开视频碰碰碰| 欧美性猛交丰臀xxxxx网站| 国产在线精品播放| 91影院在线免费观看视频| 亚洲精品二三区| 久久久久国色av免费观看性色| 黄色成人在线播放| 亚洲精品视频在线播放| 国产成人精品电影久久久| 国产成人精品视| 91po在线观看91精品国产性色| 国产亚洲视频在线| 国产精品久久久91| 欧美性生交大片免费| 色综合久久久888| 日本一区二区在线免费播放| 国产成人精品久久久| 久久久国产视频91| 久久久亚洲欧洲日产国码aⅴ| 日本亚洲欧美三级| 韩国精品久久久999| 色综合五月天导航| 欧美激情第6页| 成人免费视频网址| 麻豆一区二区在线观看| 国产极品精品在线观看| 国产一区香蕉久久| 久久久亚洲影院| 国产一区欧美二区三区| 国内精品久久久久伊人av| 亚洲福利在线观看| 亚洲专区国产精品| www国产亚洲精品久久网站| 亚洲一二三在线| www亚洲精品| 久久亚洲综合国产精品99麻豆精品福利| 国产精品午夜视频| 91在线精品播放| 国产精品男女猛烈高潮激情| 国产精品久久999| 欧美午夜电影在线| 日韩视频在线免费观看| 久久久欧美一区二区| 欧美成人一区二区三区电影| 俺去亚洲欧洲欧美日韩| 国产精品99免视看9| 2024亚洲男人天堂| 日韩精品在线免费播放| 性欧美亚洲xxxx乳在线观看| 欧美在线观看一区二区三区| 欧美精品久久久久久久免费观看| 91精品国产电影| 成人欧美在线观看| 亚洲国产精品中文| 中文字幕欧美日韩va免费视频| 91免费精品国偷自产在线| 性金发美女69hd大尺寸| 日韩免费视频在线观看| 午夜精品久久久久久久久久久久久| 欧美激情亚洲综合一区| 97国产一区二区精品久久呦| 欧美性猛交xxxx免费看漫画| 91在线观看免费高清完整版在线观看| 91精品视频专区| 亚洲美女精品久久| 欧美国产日韩一区| 亚洲美女av在线| 亚洲aⅴ男人的天堂在线观看| 日韩欧美视频一区二区三区| 日韩欧美在线国产| 青草热久免费精品视频| 久久久久一本一区二区青青蜜月| 欧美激情第一页xxx| 国产亚洲综合久久| 日韩成人网免费视频| 亚洲男子天堂网| 琪琪亚洲精品午夜在线| 九九久久久久99精品| 欧美裸体xxxx极品少妇| 亚洲人成网站777色婷婷| 国产91色在线|免| 精品日本高清在线播放| 欧美电影在线观看完整版| 国产亚洲欧美日韩精品| 在线精品国产成人综合| 国产福利精品av综合导导航| 久久免费高清视频| 欧美日韩亚洲成人| 欧美激情xxxxx| 97久久精品在线| 日韩av电影免费观看高清| 日韩电影第一页| 午夜精品久久久久久久久久久久| 北条麻妃在线一区二区| 国产日韩在线亚洲字幕中文| 91九色单男在线观看| 青青草一区二区| 久久视频精品在线| 国产成人精品日本亚洲| 亚洲成年人影院在线| 最新69国产成人精品视频免费| 日韩美女在线观看一区| 成人黄色午夜影院| 久久久这里只有精品视频| 精品欧美aⅴ在线网站| 亚洲欧美日韩中文在线制服| 亚洲三级免费看| 亚洲一级黄色av| 黄色精品在线看| 久久精品久久久久电影| 法国裸体一区二区| 欧美激情精品久久久久久久变态| 久久人体大胆视频| 欧美色播在线播放| 欧美性生活大片免费观看网址| 国产精品观看在线亚洲人成网| 久久艹在线视频| 国产中文字幕91| 亚洲欧洲视频在线| 欧美性视频网站| 欧美成人久久久| 欧美激情精品久久久久久黑人| 久久精品久久久久久国产 免费| 欧美壮男野外gaytube| 亚洲成人av中文字幕| 色偷偷噜噜噜亚洲男人的天堂| 国产精品网址在线| 影音先锋日韩有码| 亚洲v日韩v综合v精品v| www.亚洲一区| 亚洲第一区第一页| 日韩va亚洲va欧洲va国产| 欧美电影免费观看高清完整| 国产主播在线一区| 精品久久香蕉国产线看观看亚洲| 久久久www成人免费精品张筱雨| 亚洲欧美精品在线| 久久在线免费视频| 羞羞色国产精品| 午夜精品www| 成人黄色大片在线免费观看| 久久久久久国产精品美女| 成人国产亚洲精品a区天堂华泰| 91精品国产乱码久久久久久蜜臀| 欧美美女操人视频| 欧美精品久久久久久久久| 久久精品美女视频网站| 久久全球大尺度高清视频| 狠狠躁夜夜躁人人爽超碰91| 国产aaa精品| 高清视频欧美一级| 国产精品一区专区欧美日韩| 欧美日韩高清区| 欧美体内谢she精2性欧美| 欧美大荫蒂xxx| 国产色婷婷国产综合在线理论片a| 久久久久久久久国产精品| 国产日韩在线看| 日韩av电影在线网|