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

主頁(yè) > 知識(shí)庫(kù) > 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語(yǔ)言中,自身已經(jīng)集成了一定log模塊,開發(fā)者可以使用go語(yǔ)言自身的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è)日志庫(kù)。實(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)簽:滄州 晉中 阿壩 東營(yíng) 瀘州 駐馬店 泰安 昭通

巨人網(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)的同類信息!
  • 本頁(yè)收集關(guān)于golang log4go的日志輸出優(yōu)化詳解的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    天天色 色综合| 91成人免费在线视频| 国产精品成人网| 欧美成人精品二区三区99精品| 欧美mv和日韩mv国产网站| 中文字幕亚洲视频| 日韩和欧美一区二区三区| 视频一区欧美精品| 99久久精品国产一区二区三区| 欧美一二区视频| 日韩和欧美一区二区| 欧美专区在线观看一区| 久久精品一二三| 激情久久五月天| 欧美欧美欧美欧美首页| 亚洲电影激情视频网站| 91福利在线看| 亚洲美女屁股眼交3| 99re成人在线| 亚洲精品ww久久久久久p站| 成人福利电影精品一区二区在线观看 | 日韩不卡一区二区| 欧美一区二区成人| www.爱久久.com| 亚洲综合在线五月| 91精品蜜臀在线一区尤物| 亚洲激情在线激情| 欧美综合亚洲图片综合区| 国内精品不卡在线| 亚洲国产美国国产综合一区二区| 91成人看片片| 美腿丝袜亚洲一区| 综合久久国产九一剧情麻豆| 欧美久久久久免费| 激情综合色播激情啊| 中文字幕在线一区免费| 欧美老肥妇做.爰bbww| 国产福利一区二区三区| 亚洲精品国久久99热| 日韩小视频在线观看专区| 91亚洲国产成人精品一区二区三| 亚洲电影第三页| 中文字幕av资源一区| 91麻豆精品国产91久久久使用方法| 国产伦精品一区二区三区免费| 亚洲综合免费观看高清在线观看| 久久天天做天天爱综合色| 91在线看国产| 国产精品综合一区二区三区| 亚洲激情成人在线| 亚洲欧美日韩国产另类专区| 国产精品理论在线观看| 久久久91精品国产一区二区精品| 精品国产髙清在线看国产毛片| 国产成人综合网| 亚欧色一区w666天堂| 一道本成人在线| 午夜精品福利一区二区三区av | 激情综合色丁香一区二区| 久久亚洲免费视频| 色综合欧美在线视频区| 亚洲综合激情小说| 国产三级一区二区| 欧美日韩一区三区| av在线播放不卡| 看片网站欧美日韩| 中文字幕日本不卡| 欧美日韩五月天| 成人的网站免费观看| 蜜臀av一区二区| 国产精品成人在线观看| 欧美一级视频精品观看| 色综合久久中文综合久久97| 日本在线不卡视频一二三区| 国产精品伦理在线| 欧美成人伊人久久综合网| 91久久免费观看| 国产**成人网毛片九色 | 久久久精品综合| 欧美日韩精品一区二区在线播放| 国产精品996| 免费成人在线网站| 日日夜夜免费精品| 亚洲一区二区高清| 亚洲欧洲日韩综合一区二区| 久久久亚洲精品一区二区三区| 欧美视频一区二区| 一本一本大道香蕉久在线精品 | 91视频你懂的| 9色porny自拍视频一区二区| 福利91精品一区二区三区| 国产精品自产自拍| 高清av一区二区| 成人一区在线观看| 国产麻豆成人传媒免费观看| 日韩一区精品视频| 天天射综合影视| 亚洲午夜精品一区二区三区他趣| 洋洋成人永久网站入口| 亚洲图片一区二区| 亚洲午夜羞羞片| 日韩一区精品字幕| 精品一区二区三区免费毛片爱 | 欧美韩日一区二区三区四区| 日韩精品一区国产麻豆| 欧美一区午夜视频在线观看| 欧美性感一区二区三区| 欧美三级日韩三级| 欧美一区二区高清| 日韩一区二区视频| 国产亚洲短视频| 亚洲品质自拍视频| 日韩二区三区四区| 国产成人av影院| 日本高清无吗v一区| 欧美午夜电影在线播放| 69久久夜色精品国产69蝌蚪网| 日韩欧美资源站| 国产亚洲欧美色| 国产精品视频看| 亚洲一区二区五区| 热久久免费视频| 美女视频一区二区三区| 久久精品国产亚洲一区二区三区 | 精品国产91亚洲一区二区三区婷婷| 91精品国产综合久久蜜臀| 精品成人免费观看| 亚洲欧美在线视频观看| 亚洲成人精品一区| 久久av资源站| 91在线精品一区二区三区| 欧美日韩一级片在线观看| 精品国精品自拍自在线| 一区二区三区在线影院| 精品中文字幕一区二区小辣椒| 国产精品一区二区久激情瑜伽| 成人激情免费网站| 欧美老肥妇做.爰bbww视频| 久久天堂av综合合色蜜桃网| 一区二区三区精品| 国产精品一区二区不卡| 欧美色涩在线第一页| 国产欧美精品国产国产专区| 夜夜精品视频一区二区| 国产成人免费视| 在线电影院国产精品| 国产精品免费视频观看| 日韩精品一级中文字幕精品视频免费观看 | 香蕉成人啪国产精品视频综合网| 五月天国产精品| 国产精品亚洲一区二区三区在线| 欧美午夜精品理论片a级按摩| 国产片一区二区| 日本aⅴ免费视频一区二区三区| 成人蜜臀av电影| 日韩一级免费观看| 亚洲国产欧美日韩另类综合 | 亚洲精品免费播放| 韩国av一区二区三区四区| 在线不卡欧美精品一区二区三区| 亚洲v精品v日韩v欧美v专区| 9色porny自拍视频一区二区| 亚洲精品一区在线观看| 午夜精品福利一区二区蜜股av | 久久www免费人成看片高清| 欧美日韩精品系列| 亚洲一区二区精品3399| 欧美中文字幕一区二区三区亚洲| 中文字幕欧美区| 国产ts人妖一区二区| 久久综合九色综合97_久久久| 蜜臀av性久久久久av蜜臀妖精| 欧美日韩在线三级| 亚洲国产视频网站| 欧美日本在线看| 亚洲国产日韩一级| 欧美自拍偷拍一区| 欧美日韩三级一区| 午夜精彩视频在线观看不卡| 欧美日韩国产美| 天天综合网 天天综合色| 91福利精品视频| 一区二区三区日本| 99九九99九九九视频精品| 久久久亚洲高清| 美女视频黄免费的久久 | 欧美无砖专区一中文字| 亚洲亚洲人成综合网络| 欧美精品精品一区| 久久国产婷婷国产香蕉| 欧美白人最猛性xxxxx69交| 日韩国产一二三区| 日韩欧美一区中文| 激情都市一区二区| 中文字幕一区二区三区av| 91视频xxxx| 午夜精品福利视频网站| 欧美在线免费观看亚洲| 免费xxxx性欧美18vr| 日韩一级黄色片|