成人性生交大片免费看视频r_亚洲综合极品香蕉久久网_在线视频免费观看一区_亚洲精品亚洲人成人网在线播放_国产精品毛片av_久久久久国产精品www_亚洲国产一区二区三区在线播_日韩一区二区三区四区区区_亚洲精品国产无套在线观_国产免费www

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

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

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

前言

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

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

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

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

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

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

log4go 將屏幕日志輸出 termlog 放在了結(jié)構(gòu)里,這帶來一個小問題。當(dāng)我們用log4go調(diào)試小程序時,運(yùn)行的太快,termlog 的 goroutine 還沒有運(yùn)行起來,程序就退出了。結(jié)果屏幕上沒有顯示日志。這個問題只能通過在 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,仍然放在結(jié)構(gòu)里。這樣,調(diào)試小程序和生產(chǎn)程序可以使用同一個日志庫。實(shí)測效率略有降低。不知道 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ù)來獲取源文件名和行號。它是昂貴的——消耗了CPU。建議在生產(chǎn)環(huán)境中關(guān)閉,log.SetSkip(-1) 。如果要對log4go進(jìn)行封裝,設(shè)置 log.SetSkip(log.GetSkip()+1) 。

format優(yōu)化

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

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

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

在log里邊自備了一個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:]...)
}

用這個函數(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

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

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

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

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

總結(jié)

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

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

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

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《golang log4go的日志輸出優(yōu)化詳解》,本文關(guān)鍵詞  golang,log4go,的,日志,輸出,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(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)民參考!
  • 推薦文章
    亚洲天堂精品在线观看| 亚洲视频 欧洲视频| 黄色大片中文字幕| 国产偷久久久精品专区| 亚洲乱码国产乱码精品精软件| 一区二区三区视频国产日韩| 国产一区二区精品久久| 美国成人毛片| 2023国产一二三区日本精品2022| 国产专区精品视频| 精品爆乳一区二区三区无码av| a毛片在线看免费观看| 日韩少妇高潮抽搐| 日本成人超碰在线观看| 手机在线理论电影| av免费在线电影| 在线黄色网页| 成人av在线一区二区| 亚洲人成在线观| 欧美日韩亚洲国产综合| av中文字幕在线观看| 欧美成人三级在线视频| 亚洲综合一区二区三区| 天堂网在线观看国产精品| 免费在线欧美黄色| 亚洲国产毛片aaaaa无费看| 97成人资源| 中文字幕视频一区二区| 国产伦精品一区二区三区88av| 日韩欧美视频在线| 久久精品国产视频| 久久成人一区二区| 久久免费高清视频| 粉嫩一区二区三区国产精品| 欧美成人精品福利网站| 免费人成视频在线播放| 又黄又爽无遮挡| 欧美日韩国产中文精品字幕自在自线| 亚洲校园欧美国产另类| 国产精品va视频| 成人欧美一区二区三区在线| 欧美精品视频www在线观看| 欧美a级片一区| 伊人伊成久久人综合网站| 免费在线观看的黄色网址| 蜜桃av中文字幕| 视频一区免费观看| 亚洲一二三四久久| 国产精品久久久久影院色老大| 成人影院免费观看| 亚洲最大免费视频| 日本欧美色综合网站免费| 少妇人妻无码专区视频| 欧美激情久久久久久久久久久| 精品视频一区在线| 日韩中文欧美在线| 亚洲激情综合网| 成人av电影在线网| 黄色片在线观看网站| 九九色在线视频| 大胆欧美人体视频| 人妻精品一区二区三区| 久久99热精品这里久久精品| 97精品国产97久久久久久春色| jizz18日本| 波多野结衣视频在线观看| 日本一本二本在线观看| 欧美激情福利视频在线观看免费| 亚洲一区二区在线免费观看| 日日摸夜夜添夜夜添精品视频| 日韩影院一区| 成人观看高清在线观看免费| 影音先锋亚洲电影| 久草在线免费资源站| 国产女人被狂躁到高潮小说| 乱人伦xxxx国语对白| 黑人操亚洲人| 日本а中文在线天堂| 欧洲亚洲精品久久久久| 在线亚洲高清视频| 1024手机在线观看你懂的| 内射国产内射夫妻免费频道| 日本99精品| 国产精品网站在线播放| 欧美激情国内自拍| 国产爆乳无码一区二区麻豆| 亚洲一区二区小说| 国产chinese精品一区二区| 无码国产精品一区二区免费式直播| 欧美成人高清手机在线视频| 五月婷婷中文字幕| 国产在线视频三区| 午夜精品福利在线观看| 国产亚洲精彩久久| 蜜桃成人免费视频| 一区二区三区视频免费观看| 亚洲韩国一区二区三区| 中文字幕日韩一区二区不卡| 一区二区三区免费在线看| 久久999免费视频| 精彩视频一区二区| 激情六月丁香婷婷| 色视频免费版高清在线观看| 国产又爽又黄视频| 午夜视频一区二区三区| 亚洲国产成人精品一区二区三区| 亚洲欧美自偷自拍| 亚洲欧美综合7777色婷婷| 亚洲妇女成熟| 亚洲欧洲日韩一区二区三区| 亚洲va韩国va欧美va精四季| 欧美精品vⅰdeose4hd| av在线资源观看| 国产亚洲一区二区手机在线观看| 国产精品三区www17con| 免费电影日韩网站| 日本一卡二卡四卡精品| 欧美乱大交xxxxx潮喷l头像| 无码人妻精品一区二区三区不卡| 中文字幕一区二区三区免费视频| 中文字幕一区二区三区精彩视频| 美女一区二区久久| 野花视频免费在线观看| 国产网站麻豆精品视频| 四虎国产精品永久在线| 男人天堂av在线播放| 香蕉视频在线播放| 男人本色网站| 成人免费观看在线| av在线电影网站| 成年女人的天堂在线| 成人h动漫精品一区二区下载| 国产人妻互换一区二区| 亚洲丝袜在线视频| 4438全国亚洲精品在线观看视频| 国产精品免费电影| 麻豆精品在线视频| 美日韩精品免费视频| 亚洲主播在线播放| 超碰av在线免费观看| 四虎久久影院| 一本综合久久| 2023国产在线观看| 欧美超强性xxxxx| 中文字幕在线有码| 91看片破解版| 欧美日韩不卡在线| 日韩成人18| 伊人成人开心激情综合网| 色婷婷视频在线| 欧美国产日韩中文字幕在线| 亚洲人成网在线播放| 欧美激情综合色| 亚洲国产综合在线观看| 免费国产黄线在线观看视频| 久久久91精品国产| 国内精品久久久久久中文字幕| 在线资源免费观看| 韩国日本一区二区三区| 深爱激情综合| 色爱av美腿丝袜综合粉嫩av| 蜜桃精品wwwmitaows| 成人羞羞国产免费| 国产日韩精品入口| 日韩视频一二三| 久久精品视频免费观看| 国产97在线观看| 天天操夜夜操天天射| 六月丁香综合在线视频| 国产一区二区| 久久综合给合久久狠狠狠97色69| 国产成人自拍高清视频在线免费播放| 永久免费不卡在线观看黄网站| 久久综合色天天久久综合图片| 大香煮伊手机一区| 久久久久亚洲综合| 天天操天天射天天爽| 激情六月综合| 中日韩av在线播放| 97久久人人超碰caoprom欧美| 天天操 夜夜操| 久久精品一二区| 欧美久久久久久久久久久久久| 国产精品第七影院| 熟妇高潮精品一区二区三区| 男女爱爱网站| 中文乱码字幕高清一区二区| 影视亚洲一区二区三区| 国产一级片91| 国产精品手机视频| 中文字幕永久免费视频| 偷偷操不一样的久久| 无码人妻一区二区三区免费n鬼沢| 一本一本久久a久久综合精品| 国语自产精品视频在线看抢先版图片| 亚洲一区二区三区黄色| 成人免费直播在线| 国精产品久拍自产在线网站| aa片在线观看视频在线播放| 亚洲精品国产一区二区在线| 国产嫩草在线观看| 蜜桃精品视频在线| 国内伊人久久久久久网站视频| 国产久卡久卡久卡久卡视频精品| 美女黄色网址| 成年人网站在线观看免费| 国产麻豆成人精品| 丰满肉肉bbwwbbww| 亚洲欧美综合区自拍另类| 免费91在线视频| 日韩高清人体午夜| 日本高清久久久| 国产精品久久久久久久久电影网| 亚洲精品国产熟女久久久| av免费在线免费| 高清av免费一区中文字幕| 欧美一级片免费在线| 国语对白永久免费| 日本精品一区二区三区在线| 熟年交尾五十路视频在线播放| 亚洲人午夜色婷婷| 色综合视频一区中文字幕| 欧美videofree性高清杂交| 日韩视频一二区| 亚洲国产综合在线观看| 久久只有这里有精品| 亚洲成人网在线播放| 丝袜美腿亚洲综合| 免费欧美一区| 国产亚洲成aⅴ人片在线观看| 欧美特黄一区| 少妇人妻互换不带套| 日韩福利在线观看| 欧美精品一区二区三区在线四季| 久久久久99精品成人片我成大片| 99热在线观看| 免费成人三级| 日韩理论电影大全| 狂野欧美激情性xxxx欧美| 天堂а√在线中文在线鲁大师| 欧美影院三区| 成人免费毛片app| 国产不卡精品视男人的天堂| 日韩午夜激情视频| 91国偷自产中文字幕久久| 在线成人小视频| 台湾佬成人中文网222vvv| 奇米亚洲欧美| 青青草原综合久久大伊人精品优势| 成人在线不卡| 国产一区激情| 综合136福利视频在线| av资源新版天堂在线| 俺去亚洲欧洲欧美日韩| 国产亚洲欧美中文| 亚洲风情在线资源| 色综合手机在线| 国产成人精品无码高潮| 中文字幕欧美精品日韩中文字幕| 久久久爽爽爽美女图片| 香蕉视频免费在线| 国产一区二区三区朝在线观看| 亚洲欧洲国产一区| 亚洲色图欧美| 色网站免费在线观看| 99在线|亚洲一区二区| 91短视频推广| 91肉色超薄丝袜脚交一区二区| 亚洲国产果冻传媒av在线观看| 色诱女教师一区二区三区| 欧美专区国产专区| 成人精品一区二区| 人妻丰满熟妇av无码区hd| 91精品国产91久久久久游泳池| 人人妻人人做人人爽| 中文字幕无码毛片免费看| 久久久久久久久一区二区| www.亚洲色图.com| 欧美一区1区三区3区公司| 日av在线播放| 国产精品三级在线观看无码| 精品国产二区三区| 国产精选久久久| 亚洲精品无码久久久久久久| 国产精品一区2区3区| 中文日本在线观看| 亚洲欧美日韩精品久久奇米色影视| 91.xxx.高清在线| 国产日韩精品一区| 日韩av综合网站| 97se国产在线视频| 免费v片在线观看| 国产欧美成人xxx视频| 白白色亚洲国产精品| 国产精品视频线看| 亚洲一区二区不卡视频| 96久久久久久| 亚洲成人av一区二区三区| 久久久欧美一区二区| 欧美色图第二页| 一本色道久久综合狠狠躁篇怎么玩| 国产在线观看免费麻豆| 国产午夜福利100集发布| 视频一区 中文字幕| 免费一区二区在线观看| 国产在线视频91| 成人久久精品| 巨茎人妖videos另类| 国产不卡一区二区视频| 久久久久久高清| 最新国产热播激情视频| 一二三区视频在线观看| 国产伦精品一区三区精东| 精品国产福利在线| 久久久久亚洲AV成人网人人小说| 亲子伦视频一区二区三区| 免费在线观看污视频| 久久久久久久999精品视频| 成人三级在线视频| 国产在线高清视频| 欧美一级中文字幕| 亚洲一区二区三区视频在线播放| 一区二区在线免费视频| 日韩www在线| 国产精品福利一区| 欧美床上激情在线观看| 亚洲激情第一页| 在线亚洲自拍|