亚洲综合原千岁中文字幕_国产精品99久久久久久久vr_无码人妻aⅴ一区二区三区浪潮_成人h动漫精品一区二区三

主頁 > 知識(shí)庫 > golang log4go的日志輸出優(yōu)化詳解

golang log4go的日志輸出優(yōu)化詳解

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

前言

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

當(dāng)前也有一些比較重量級(jí)的log模塊,比如logrus,可以實(shí)現(xiàn)比較復(fù)雜的功能。這里介紹一個(gè)輕量級(jí)的log模塊——log4go

最近又看了一些golang的日志包和相關(guān)的文章,仔細(xì)閱讀了go 1.9.2系統(tǒng)提供的log和go-log,產(chǎn)生了對(duì)log4go的日志輸出進(jìn)行優(yōu)化的想法。

結(jié)構(gòu)化與multiwriter

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

原來以為 channel 的效率比較高……其實(shí)這是一個(gè)偽命題。channel 是一個(gè)全局加鎖的隊(duì)列,可以用來加鎖,但效率比較低。因?yàn)樗嗔藗鬟f數(shù)據(jù)、協(xié)調(diào)順序處理、timout等功能,并不僅僅是加鎖。跟Mutex不是一回事兒。

log4go 將屏幕日志輸出 termlog 放在了結(jié)構(gòu)里,這帶來一個(gè)小問題。當(dāng)我們用log4go調(diào)試小程序時(shí),運(yùn)行的太快,termlog 的 goroutine 還沒有運(yùn)行起來,程序就退出了。結(jié)果屏幕上沒有顯示日志。這個(gè)問題只能通過在 Close() 時(shí)加延時(shí),等待 goroutine 啟動(dòng)來解決。然后還要檢查 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,仍然放在結(jié)構(gòu)里。這樣,調(diào)試小程序和生產(chǎn)程序可以使用同一個(gè)日志庫。實(shí)測(cè)效率略有降低。不知道 windows 下的 ColorLog 如何,以后再說。

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

Determine caller func - it's expensive

這句話注釋在 log 源文件中,log4go也要調(diào)用runtime.Caller(skip int)函數(shù)來獲取源文件名和行號(hào)。它是昂貴的——消耗了CPU。建議在生產(chǎn)環(huán)境中關(guān)閉,log.SetSkip(-1) 。如果要對(duì)log4go進(jìn)行封裝,設(shè)置 log.SetSkip(log.GetSkip()+1)

format優(yōu)化

其實(shí),這才是文章的主題。

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

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

在log里邊自備了一個(gè)cheap的itoa函數(shù)。

// 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:]...)
}

用這個(gè)函數(shù)替換日期和時(shí)間的字符串格式化函數(shù)。用[]byte代替string。

優(yōu)化前,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

優(yōu)化后:

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

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

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

BenchmarkConsoleUtilLog調(diào)用了runtime.Caller,格式化信息,且新增了輸出信息到屏幕的時(shí)間。

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

總結(jié)

以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,如果有疑問大家可以留言交流,謝謝大家對(duì)腳本之家的支持。

您可能感興趣的文章:
  • Golang報(bào)“import cycle not allowed”錯(cuò)誤的2種解決方法
  • Golang常見錯(cuò)誤之值拷貝和for循環(huán)中的單一變量詳解
  • Golang巧用defer進(jìn)行錯(cuò)誤處理的方法
  • golang新手們?nèi)菀追傅?個(gè)錯(cuò)誤總結(jié)
  • Golang中重復(fù)錯(cuò)誤處理的優(yōu)化方法

標(biāo)簽:滄州 晉中 阿壩 東營 瀘州 駐馬店 泰安 昭通

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《golang log4go的日志輸出優(yōu)化詳解》,本文關(guān)鍵詞  golang,log4go,的,日志,輸出,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《golang log4go的日志輸出優(yōu)化詳解》相關(guān)的同類信息!
  • 本頁收集關(guān)于golang log4go的日志輸出優(yōu)化詳解的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    韩国三级一区| 欧美激情一区二区三区在线播放 | 国产亚洲精品成人a在线| 久草免费在线视频| 精品在线视频播放| 久久国产精品永久免费网站| 99久久精品国产高清一区二区| 欧美爱爱网| 色综合久久久久综合体桃花网| 国产不卡福利| 毛片高清| 一级女人毛片人一女人| 九九精品在线| 欧美激情影院| 日本在线播放一区| 亚洲天堂一区二区三区四区| 成人免费高清视频| 欧美18性精品| 二级片在线观看| 日韩男人天堂| 黄视频网站免费看| 精品久久久久久中文字幕一区 | 国产成人精品影视| 国产a毛片| 黄色免费三级| 你懂的在线观看视频| 国产麻豆精品高清在线播放| 国产一区精品| 午夜激情视频在线观看| 亚州视频一区二区| 美女免费精品高清毛片在线视 | 亚洲www美色| 国产国语对白一级毛片| 国产网站免费| 亚洲天堂一区二区三区四区| 国产美女在线一区二区三区| 九九干| 亚州视频一区二区| 成人高清视频在线观看| 久久久久久久久综合影视网| 日韩中文字幕在线观看视频| 日本伦理片网站| 精品在线视频播放| 台湾毛片| 天天做日日爱夜夜爽| 日本久久久久久久 97久久精品一区二区三区 狠狠色噜噜狠狠狠狠97 日日干综合 五月天婷婷在线观看高清 九色福利视频 | 日韩欧美一及在线播放| 国产麻豆精品| 午夜在线观看视频免费 成人| 中文字幕一区二区三区精彩视频| 欧美激情一区二区三区在线播放 | 一本伊大人香蕉高清在线观看| 日韩av成人| 成人av在线播放| 久久99中文字幕久久| 日韩一级黄色片| 精品久久久久久综合网| 国产成人精品综合久久久| 欧美一级视频高清片| 中文字幕Aⅴ资源网| 国产亚洲男人的天堂在线观看| 日本久久久久久久 97久久精品一区二区三区 狠狠色噜噜狠狠狠狠97 日日干综合 五月天婷婷在线观看高清 九色福利视频 | 欧美激情中文字幕一区二区| 黄视频网站免费| 久久久久久久久综合影视网| 99久久精品国产麻豆| 国产亚洲精品成人a在线| 成人影院一区二区三区| 超级乱淫伦动漫| 四虎精品在线观看| 国产不卡福利| 欧美a级大片| 午夜激情视频在线观看| 台湾毛片| 亚洲 激情| 国产视频久久久久| 韩国三级视频网站| 中文字幕Aⅴ资源网| 国产福利免费视频| 欧美激情一区二区三区在线| 成人影视在线播放| 国产网站免费视频| 精品视频在线观看一区二区| 91麻豆爱豆果冻天美星空| 免费一级片在线| 精品国产三级a| 久久国产一久久高清| 亚洲精品中文字幕久久久久久| 亚洲精品永久一区| 亚洲精品永久一区| 午夜激情视频在线观看| 欧美另类videosbestsex| 国产激情一区二区三区| 国产视频一区二区三区四区 | 日韩专区第一页| 成人免费高清视频| 免费国产在线观看| 精品在线观看国产| 国产视频一区二区三区四区 | 久久久久久久网| 91麻豆精品国产自产在线观看一区| 日本久久久久久久 97久久精品一区二区三区 狠狠色噜噜狠狠狠狠97 日日干综合 五月天婷婷在线观看高清 九色福利视频 | 在线观看成人网 | 韩国毛片免费大片| 欧美夜夜骑 青草视频在线观看完整版 久久精品99无色码中文字幕 欧美日韩一区二区在线观看视频 欧美中文字幕在线视频 www.99精品 香蕉视频久久 | 91麻豆精品国产片在线观看| 精品久久久久久中文字幕一区 | 成人免费高清视频| 欧美大片aaaa一级毛片| 黄视频网站免费| 日韩在线观看免费完整版视频| 色综合久久天天综合| 欧美日本二区| 精品在线观看国产| 美女免费精品高清毛片在线视 | 国产麻豆精品高清在线播放| 日本久久久久久久 97久久精品一区二区三区 狠狠色噜噜狠狠狠狠97 日日干综合 五月天婷婷在线观看高清 九色福利视频 | 日韩av成人| 青草国产在线| 久久久久久久久综合影视网| 日韩中文字幕在线观看视频| 久久精品大片| 999久久久免费精品国产牛牛| 四虎影视库| 超级乱淫伦动漫| 台湾毛片| 韩国毛片 免费| 九九久久国产精品大片| 欧美激情一区二区三区在线播放 | 国产成人精品影视| 午夜在线观看视频免费 成人| 国产福利免费视频| 成人影视在线播放| 青青久久精品| 青草国产在线| 亚洲 激情| 日本免费乱理伦片在线观看2018| 可以免费在线看黄的网站| 日本伦理片网站| 午夜激情视频在线观看| 日韩专区第一页| 亚飞与亚基在线观看| 青草国产在线| 色综合久久久久综合体桃花网| 国产亚洲男人的天堂在线观看| 韩国毛片免费大片| 青青久久精品| 999精品视频在线| 久久国产影视免费精品| 九九久久99综合一区二区| 精品在线视频播放| 日韩一级黄色| 你懂的在线观看视频| 国产a毛片| 精品在线视频播放| 日本在线播放一区| 韩国毛片 免费| 可以免费看毛片的网站| 一级女人毛片人一女人| 国产一区二区精品在线观看| 亚洲www美色| 欧美激情伊人| 国产一区二区高清视频| 美女被草网站| 美女免费毛片| 你懂的福利视频| 九九久久99综合一区二区| 亚洲精品永久一区| 国产视频一区二区在线播放| 午夜在线观看视频免费 成人| 日日夜人人澡人人澡人人看免| 国产一区二区精品| 精品国产一区二区三区久| 午夜在线观看视频免费 成人| 精品国产亚洲一区二区三区| 国产a视频精品免费观看| 成人免费观看视频| 99色视频| 亚洲第一色在线| 欧美激情一区二区三区视频高清| 国产亚洲男人的天堂在线观看| 四虎影视久久| 久草免费在线观看| 免费的黄视频| 你懂的福利视频| 亚洲天堂免费| 国产一区二区精品久久91| 韩国三级一区| 999久久66久6只有精品| 四虎影视久久| 欧美a级大片| 韩国三级一区| 好男人天堂网 久久精品国产这里是免费 国产精品成人一区二区 男人天堂网2021 男人的天堂在线观看 丁香六月综合激情 | 欧美激情伊人| 国产视频久久久久| 欧美18性精品| 久久精品大片| 免费一级生活片| 精品国产一区二区三区久| 日韩在线观看视频免费|