午夜视频免费看_日韩三级电影网站_国产精品久久一级_亚洲一级在线播放_人妻体内射精一区二区三区_91夜夜揉人人捏人人添红杏_91福利在线导航_国产又粗又猛又黄又爽无遮挡_欧美日韩一区在线播放_中文字幕一区二区三区四区不卡 _日日夜夜精品视频免费观看_欧美韩日一区二区三区

主頁 > 知識庫 > 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的日志輸出優化詳解的相關信息資訊供網民參考!
  • 推薦文章
    久久国产色av免费观看| 无码h肉动漫在线观看| 亚洲深夜福利视频| 91l九色lporny| 在线国产亚洲欧美| 免费观看黄色大片| 免费三片在线播放| 国产午夜一区二区| 久久精品视频7| 国产精品二区在线观看| 亚洲日本丝袜连裤袜办公室| 精品人妻一区二区三区日产乱码卜| 国自产精品手机在线观看视频| 日本美女一区二区三区视频| 视频一区视频二区视频| 亚洲国产高清在线| 欧美系列一区| 2017欧美狠狠色| 亚洲成人在线视频网站| 麻豆精品精品国产自在97香蕉| 久久99亚洲热视| 久久蜜桃精品| 久久久久久av无码免费网站下载| 亚洲精品久久久蜜桃| 国产精品久久综合av爱欲tv| 日本激情视频一区二区三区| 亚洲韩国青草视频| www..com.cn蕾丝视频在线观看免费版 | 奇米777在线| 91精品人妻一区二区三区蜜桃欧美| 顶臀精品视频www| 日韩在线视频不卡| 人成网站在线观看| 国产大片一区二区| 中文字幕亚洲一区二区va在线| 日韩欧美有码在线| 精品福利视频一区二区三区| 日韩一区二区在线视频| 国产精品pans私拍| 蜜桃日韩视频| 黄色免费福利视频| 中国xxxx性xxxx产国| 日本精品人妻无码77777| 中文字幕乱码一区二区 | 中文在线观看av| 久久一区二区三区四区五区| 成人性视频免费网站| 亚洲精品欧美激情| 欧美一区二区精品久久911| 中文综合在线观看| 国产精品video| 欧美男人的天堂| 日韩精品视频一区二区在线观看| 日韩无码精品一区二区| 日本在线免费观看| 色哟哟中文字幕| 99re66热这里只有精品3直播 | 日韩男人的天堂| 欧美天堂在线视频| 91视频免费观看| 色综合天天综合网天天看片| 日韩国产精品亚洲а∨天堂免| 98精品在线视频| 久久久久久国产精品mv| 精品中文字幕av| 波多野结衣片子| 波多野结衣一本一道| 麻豆国产精品官网| 亚洲男女一区二区三区| 日韩免费性生活视频播放| 久久久久久国产精品三级玉女聊斋| 高清国产在线一区| 久久手机在线视频| 青青草视频播放| 黄色av网站免费| 国产尤物一区二区| 亚洲成人av一区| 亚洲欧美日韩国产中文| 国产欧美中文字幕| 欧美一二三不卡| 欲求不满的岳中文字幕| 在线观看污污网站| 国产美女精品一区二区三区| 亚洲一区二区三区免费视频| 日韩精品视频在线观看网址| 国产精品国产三级国产aⅴ9色| 宅男av一区二区三区| 18禁一区二区三区| 激情视频网站在线观看| 国产精品99久久久| 色综合久久中文字幕综合网| 俺也去精品视频在线观看| 国产不卡一区二区在线观看| 日韩中文字幕二区| 麻豆精品一区二区三区视频| 久久狠狠一本精品综合网| 最新日韩在线视频| 日韩大陆毛片av| 91精品国产综合久久香蕉| 久久综合久久久久| 国产精品成人无码免费| 精品人妻伦一二三区久久| 国产视频911| 日韩欧美二区三区| 国产精品69av| 黄色一级片国产| 99久久人妻无码精品系列| 午夜精品无码一区二区三区| 欧美激情综合五月色丁香小说| 日韩欧美三级在线| 国产精品美乳在线观看| 免费在线观看视频a| 日韩av网站在线播放| 午夜视频在线免费播放| 夜夜爽夜夜爽精品视频| 在线一区二区日韩| 精品无人乱码一区二区三区的优势| 天天操狠狠操夜夜操| 亚洲国产成人精品女人久久| 99久久国产免费看| 日韩三级在线观看| 国产欧美精品久久久| wwwxxx黄色片| 日本少妇毛茸茸高潮| 国产成人精品www牛牛影视| 欧美日韩国产精品成人| 热99在线视频| av免费观看大全| 欧美日韩国产精品一区二区三区| 狠狠色丁香久久婷婷综| 欧美日韩一区二区三区视频| 欧洲成人免费aa| 免费看国产曰批40分钟| 久青草视频在线观看| 国产美女娇喘av呻吟久久| 欧美体内she精视频| 日本久久精品视频| 99爱视频在线| 在线观看中文字幕视频| 97久久久精品综合88久久| 精品久久国产字幕高潮| 97视频中文字幕| 亚洲av毛片在线观看| 国产精品久久久久精| 国产精品国产三级国产aⅴ中文 | 久久99国产精品久久99| 欧美中文字幕一区二区三区亚洲| 8050国产精品久久久久久| 加勒比成人在线| 日本a在线观看| 91在线观看一区二区| 日韩精品免费在线视频| 久久伦理网站| 天天躁日日躁aaaxxⅹ | 青青精品视频播放| 无遮挡又爽又刺激的视频| 在线精品免费视| 欧美国产成人在线| 中文字幕欧美精品在线| 一区二区免费电影| 免费三级在线观看| 成人a区在线观看| 国产视频综合在线| 水蜜桃一区二区三区| 2014亚洲天堂| 成人网在线播放| 日韩精品中文字幕有码专区| 欧美日韩精品免费看| 国产全是老熟女太爽了| 久久超碰97中文字幕| 日韩视频免费直播| 精品视频免费观看| 四虎国产成人精品免费一女五男| 国产一区二区精品久久99| 亚洲成人久久久| 欧美日韩精品免费看| 国产免费美女视频| 91香蕉国产在线观看软件| 国产一区二区三区在线观看网站| 中文字幕成人一区| 国产无遮挡裸体免费视频| 久久精品一区二区三区四区| 久久精彩免费视频| 黄色www网站| 国产有码在线观看| 欧美色视频日本版| 91久久精品久久国产性色也91| 少妇伦子伦精品无吗| 日韩电影在线一区二区三区| 91精品视频网| 欧美久久久久久一卡四| 人人澡人人澡人人看| 91亚洲精品久久久蜜桃网站| 亚洲人成网站免费播放| 日本中文字幕一级片| 国产伦精品一区二区三区视频网站| 国产精品福利一区二区三区| 韩国一区二区电影| 亚洲这里只有精品| 天天操天天干天天爽| 欧美电影一区二区| 鲁鲁视频www一区二区| www欧美com| 国产精品色哟哟网站| 欧美激情伊人电影| 99热一区二区| 日日摸夜夜添夜夜添精品视频| 欧美成人aa大片| 在线成人性视频| 99精品在线播放| 亚洲午夜三级在线| 成人免费网站在线| 97在线观看免费视频| 91日韩在线专区| 欧美激情国产精品| 亚洲18在线看污www麻豆| 久久精品日产第一区二区| 欧美mv日韩mv国产网站| 中文精品一区二区三区| 无码人妻熟妇av又粗又大| 五月天国产精品| 粉嫩av免费一区二区三区| 四虎永久免费地址| 国产精品每日更新| 国产精品国内视频| 男女黄床上色视频| 91免费版在线| 97av在线视频| 日本三级日本三级日本三级极| 国产精品香蕉一区二区三区| 俺去了亚洲欧美日韩| 冲田杏梨av在线| 丝袜美腿高跟呻吟高潮一区| 日韩精品在线看| 国产在线精品91| 色丁香婷婷综合久久| 精品欧美一区二区久久| 国产成人一二三区| 亚洲av无码乱码在线观看性色| 91精品久久久久久蜜臀| 视频一区二区视频| 国产精品污视频| 日韩亚洲欧美高清| 日韩视频 中文字幕| 国产成人麻豆精品午夜在线| 日韩免费高清av| 日本大片免费看| 色婷婷av一区二区三区之红樱桃| 亚洲精品国产精品久久清纯直播| 成人黄色av片| 久久最新视频| 中文字幕少妇一区二区三区| 四季av一区二区| 国产在线精品免费| 色综合久久88| 中国一级特黄录像播放| 久久久久久久综合色一本| 国产精欧美一区二区三区| 又嫩又硬又黄又爽的视频| 日韩毛片在线免费观看| 99九九电视剧免费观看| 久久久精品国产sm调教| 午夜精品一区二区三区三上悠亚| 久99久在线| 波多野结衣视频在线观看| 欧美一区二区三区在线视频| 欧洲精品在线播放| 久久久久欧美精品| 最近2019中文字幕第三页视频 | 亚洲欧美福利一区二区| 成人av免费看| 伊人手机在线视频| 欧美男男青年gay1069videost| 天堂av免费看| 人妻中文字幕一区| 中文字幕久久亚洲| 精品国产aⅴ一区二区三区东京热| 97成人超碰视| 国产日本欧美一区二区三区| 农村黄色一级片| 色香蕉久久蜜桃| 日韩不卡一二区| 蜜桃久久av| 色综合久久精品亚洲国产| 精品黑人一区二区三区观看时间| √…a在线天堂一区| 国产中文一区二区| 中文字幕乱码无码人妻系列蜜桃| 精品国精品国产尤物美女| 亚洲国产精品毛片av不卡在线| 国产剧情在线观看一区二区| 91成人性视频| 免费三级在线观看| 欧美性色黄大片| 久久成人福利视频| 极品尤物av久久免费看| 88国产精品欧美一区二区三区| 制服丨自拍丨欧美丨动漫丨| 高潮白浆女日韩av免费看| 在线国产精品网| 久久亚洲不卡| 久久久久久久一| 二区三区四区视频| 色妞www精品视频| 国产视频在线观看网站| 美女www一区二区| 91高潮精品免费porn| 国产女人18水真多毛片18精品| 色综合久久综合网欧美综合网| 日本a级片在线播放| 麻豆精品国产传媒mv男同| 欧美在线免费视频| 久一视频在线观看| 欧美精品第1页| www.超碰com| 久久综合色之久久综合| yellow视频在线观看一区二区| 亚洲一区精品在线观看| 亚洲天堂第二页| 亚洲欧美日本一区| 亚洲成人激情综合网| 看一级黄色录像| 国产综合色在线| 国产欧美亚洲视频| 中文字幕日韩第一页| 国产午夜精品视频| 捆绑裸体绳奴bdsm亚洲| 亚洲成人一区在线| 五月天激情图片| 国产麻豆精品在线观看| 成人国内精品久久久久一区| www.av88| 色噜噜狠狠狠综合曰曰曰88av| 欧美 日韩 国产 成人 在线观看| 日韩欧美高清在线视频| 国产原创中文在线观看| 成人小视频免费观看| 2014国产精品| 国产手机av在线| 欧美日韩第一页| 精品无码久久久久久久久| 欧美电影免费观看完整版| 善良的小姨在线| 亚洲一区二区三区四区的| 黄色一级片黄色| 99久久精品费精品国产一区二区| 国产美女99p| 天堂中文资源在线观看| 日韩免费在线视频| 亚洲中文无码av在线| 色香阁99久久精品久久久| 一级免费黄色录像| 日韩一区二区电影| 国偷自产av一区二区三区麻豆| 亚洲一区二区美女| 国产伦精品一区二区三区四区视频_| 久久综合九色综合欧美亚洲| 免费成人深夜夜行视频| 免费成人在线观看视频| 成人激情在线观看| 亚洲黄色在线免费观看| 欧美专区国产专区| 最近国语视频在线观看免费播放| xvideos亚洲人网站| 欧美日韩精品在线观看视频 | 99高清视频有精品视频| 亚洲精品国产av| 日韩av成人在线观看| 国产精品51麻豆cm传媒 | 91色在线porny| 亚洲 国产 日韩 综合一区| 国产精品99久久久久久宅男| 国产精品国产三级欧美二区| 午夜激情小视频| 成人黄色av网| 婷婷在线观看视频| 国产精品午夜视频| 国产高清在线免费| 国产z一区二区三区| 国产精品一级二级| 5278欧美一区二区三区| 在线免费看91| 97婷婷涩涩精品一区| 中文字幕永久在线视频| 欧美极品欧美精品欧美视频| 天天操天天操天天操天天| 欧美成人黑人xx视频免费观看| 97免费在线观看视频| 久久深夜福利免费观看| 800av免费在线观看| 美日韩精品免费观看视频| 亚洲精品男人天堂| 九九久久综合网站| 亚洲精品77777| 久久天天躁狠狠躁夜夜爽蜜月| 91视频免费网址| 久久99精品久久久久久噜噜| 黄色一级视频免费看| 欧美精品成人在线| 在线免费av网| 热re99久久精品国产66热| 超碰福利在线观看| 91精品久久久久久久久久另类| 性xxxx搡xxxxx搡欧美| 亚洲自拍欧美色图| 蜜臀av亚洲一区中文字幕| 久久www免费人成精品| 国产91富婆露脸刺激对白| 在线观看日本一区| 中文字幕免费不卡在线|