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

主頁 > 知識(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ì)于一些簡(jiǎn)單的開發(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直接將格式化日志信息輸出到屏幕,簡(jiǎn)單多了。

試著兼顧兩者,在 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é)

以上就是這篇文章的全部?jī)?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)民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    精品无人区卡一卡二卡三乱码免费卡| 欧美美女视频在线观看| 国产一区二区在线影院| 免费成人在线播放| 午夜久久久影院| 五月婷婷欧美视频| 免费久久99精品国产| 国模冰冰炮一区二区| 国产精品一区二区三区四区| 国产在线精品国自产拍免费| 国产麻豆午夜三级精品| 99久久精品99国产精品| 色综合视频在线观看| 69av一区二区三区| 国产日韩在线不卡| 亚洲自拍偷拍综合| 91丝袜高跟美女视频| 欧美性一二三区| 91精品国产欧美日韩| 中文字幕中文字幕一区| 日本在线不卡视频一二三区| 国产麻豆成人精品| 欧美日韩国产天堂| 国产精品久久久久久久岛一牛影视| 亚洲丝袜另类动漫二区| 美腿丝袜一区二区三区| 在线观看日韩高清av| 久久综合九色综合欧美亚洲| 亚洲精品水蜜桃| 国产精品不卡在线| 久久久不卡网国产精品二区| 成人欧美一区二区三区黑人麻豆 | 亚洲女与黑人做爰| 麻豆精品一区二区三区| 一本到不卡免费一区二区| 久久在线免费观看| 日韩成人av影视| 欧美日韩mp4| 亚洲国产视频直播| 97国产一区二区| 欧美国产1区2区| 国产成人在线免费观看| 精品国产乱码久久久久久老虎| 亚洲乱码中文字幕| 成人深夜在线观看| 中文字幕av一区二区三区高| 久久精品国产77777蜜臀| 欧美一级片免费看| 久久91精品国产91久久小草| 欧美一卡二卡三卡四卡| 青青草成人在线观看| 欧美一区二区三区喷汁尤物| 美女诱惑一区二区| 精品日韩成人av| 国产不卡免费视频| 亚洲电影激情视频网站| 欧美日韩一区二区在线观看 | 欧美成人精品1314www| 日产国产欧美视频一区精品| 亚洲色图欧美激情| 欧美专区在线观看一区| 色婷婷精品久久二区二区蜜臀av| 国产精品77777| 精品国产91乱码一区二区三区| 一区二区三区四区在线播放| 中文字幕日本乱码精品影院| 精品国产一区a| 欧美国产国产综合| 亚洲最大成人综合| 欧美日韩国产高清一区二区| 成人高清视频在线观看| 色哟哟一区二区三区| 99国产欧美久久久精品| 在线一区二区视频| 在线国产亚洲欧美| ww久久中文字幕| 成人福利电影精品一区二区在线观看| 91精品婷婷国产综合久久竹菊| 国产一区二区不卡在线| 久久一夜天堂av一区二区三区| 色婷婷激情一区二区三区| 九九九久久久精品| 亚洲猫色日本管| 精品日韩欧美一区二区| 欧美一级高清片| 欧美男生操女生| 亚洲国产成人av| 亚洲一级在线观看| 亚洲一区二区在线观看视频 | 国产一区激情在线| 久久精品国产免费| 成人午夜短视频| 欧美精品日韩综合在线| 久久精品视频一区二区三区| 欧美又粗又大又爽| 国产成人精品免费网站| 亚洲黄色片在线观看| 国产精品拍天天在线| 在线欧美日韩精品| 丝袜美腿亚洲一区二区图片| 91丨九色丨黑人外教| 亚洲视频 欧洲视频| 91视频在线观看免费| 亚洲乱码国产乱码精品精98午夜| 色哟哟国产精品| 欧美综合欧美视频| 中文字幕va一区二区三区| 欧美在线短视频| 2014亚洲片线观看视频免费| 欧美性受xxxx黑人xyx性爽| 99久久99久久精品免费观看| 91在线观看成人| 欧美日韩国产精品成人| 欧美色图天堂网| 欧美成人精品福利| 国产精品久久久久影视| 亚洲国产日韩一区二区| 日韩欧美国产精品| 国内成+人亚洲+欧美+综合在线| 亚洲欧美日韩国产综合在线| 日韩一区二区三区电影在线观看| 日韩av午夜在线观看| 日日骚欧美日韩| 欧美国产97人人爽人人喊| 91一区二区在线| 91免费看片在线观看| 中文字幕不卡在线播放| 亚洲手机成人高清视频| 午夜成人免费视频| 91精品综合久久久久久| 亚洲一区二三区| 成人av在线播放网址| 99精品欧美一区二区蜜桃免费 | 一区二区三区在线影院| 懂色av一区二区三区免费观看 | 欧美一区三区四区| 国产精品国产馆在线真实露脸 | 国产成人在线免费观看| 91丝袜呻吟高潮美腿白嫩在线观看| 欧美精品一区二区三区蜜桃视频| 天堂在线亚洲视频| 7777精品久久久大香线蕉| 一区二区三区在线高清| 欧美福利一区二区| 久久99久国产精品黄毛片色诱| 欧美mv日韩mv国产| 成人成人成人在线视频| 亚洲欧美一区二区视频| www.欧美日韩| 性感美女久久精品| 日韩精品一区二区三区视频 | 久久久久亚洲蜜桃| 色屁屁一区二区| 美腿丝袜在线亚洲一区| 国产精品久久久久久户外露出| 91小视频免费看| 国产麻豆欧美日韩一区| 尤物在线观看一区| 欧美videofree性高清杂交| 日本不卡视频一二三区| 国产精品视频第一区| 91精品国产综合久久香蕉的特点| 国产麻豆视频一区| 丝袜国产日韩另类美女| 欧美国产一区视频在线观看| 6080午夜不卡| 欧美三级中文字幕| 91官网在线观看| 成人在线一区二区三区| 丁香婷婷综合网| 国产一区二区三区四| 欧美精品1区2区| 欧美亚洲禁片免费| 91原创在线视频| 色国产精品一区在线观看| 成人午夜私人影院| 成人福利视频网站| 91在线一区二区| 色综合色综合色综合| 欧美午夜电影网| 成人免费视频一区| 成人精品亚洲人成在线| 东方aⅴ免费观看久久av| 懂色av一区二区三区免费看| 高清不卡在线观看| 亚洲一级在线观看| 亚洲大片精品永久免费| 亚洲午夜一区二区| 久久99精品久久久久婷婷| 亚洲第一成人在线| 视频一区二区三区在线| 精品一区二区在线看| 成人国产精品免费观看| 欧美午夜在线观看| 欧美日韩aaaaaa| 国产欧美va欧美不卡在线| 伊人夜夜躁av伊人久久| 精品综合久久久久久8888| 成人做爰69片免费看网站| 岛国一区二区三区|