亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > Golang > 正文

golang之log rotate詳解

2020-04-01 19:05:20
字體:
來源:轉載
供稿:網友

操作系統: CentOS 6.9_x64

go語言版本: 1.8.3

問題描述

golang的log模塊提供的有寫日志功能,示例代碼如下:

/*golang log example*/package mainimport (  "log"  "os")func main() {  logFile,err := os.Create("test1.log")  defer logFile.Close()  if err != nil {    log.Fatalln("open file error!")  }  logger := log.New(logFile,"[Debug]",log.Ldate | log.Ltime | log.Lshortfile)  logger.Println("test debug message")  logger.SetPrefix("[Info]")  logger.Println("test info message")}

運行效果:

[root@local t2]# go build logTest1.go[root@local t2]# ./logTest1[root@local t2]# cat test1.log[Debug]2017/06/13 23:18:36 logTest1.go:19: test debug message[Info]2017/06/13 23:18:36 logTest1.go:21: test info message[root@local t2]#

 

go語言的log模塊沒有提供log rotate接口,但實際開發中我們需要該功能:

我們不希望單個日志過大,否則文本編輯器無法打開,查看比較困難;

更不希望占用太大的存儲空間,可以指定最多存多少個日志文件。

解決方案

借助帶緩沖的channel來實現。

示例代碼如下:

/*  golang log rotate example*/package mainimport (  "fmt"  "log"  "os"  "time")const (  BACKUP_COUNT = 5  MAX_FILE_BYTES = 2 * 1024)func doRotate(fPrefix string) {  for j := BACKUP_COUNT; j >= 1; j-- {    curFileName := fmt.Sprintf("%s_%d.log",fPrefix,j)    k := j-1    preFileName := fmt.Sprintf("%s_%d.log",fPrefix,k)    if k == 0 {      preFileName = fmt.Sprintf("%s.log", fPrefix)    }    _,err := os.Stat(curFileName)    if err == nil {      os.Remove(curFileName)      fmt.Println("remove : ", curFileName)    }    _,err = os.Stat(preFileName)    if err == nil {      fmt.Println("rename : ", preFileName, " => ", curFileName)      err = os.Rename(preFileName, curFileName)      if err != nil {        fmt.Println(err)      }    }  }}func NewLogger(fPrefix string) (*log.Logger, *os.File) {  var logger *log.Logger  fileName := fmt.Sprintf("%s.log", fPrefix)  fmt.Println("fileName :", fileName)  logFile, err := os.OpenFile(fileName, os.O_RDWR|os.O_CREATE|os.O_APPEND, 0666)  if err != nil {    fmt.Println("open file error!")  } else {    logger = log.New(logFile, "[Debug]", log.Ldate|log.Ltime|log.Lshortfile)  }  return logger, logFile}func logWorker(msgQueue <-chan string) {  fPrefix := "msg"  logger, logFile := NewLogger(fPrefix)  for msg := range msgQueue {    logger.Println(msg)    fi, err2 := logFile.Stat()    if err2 == nil {      if fi.Size() > MAX_FILE_BYTES {        logFile.Close()        doRotate(fPrefix)        logger,logFile = NewLogger(fPrefix)      }    }  }  logFile.Close()}func main() {  msgQueue := make(chan string, 1000)  go logWorker(msgQueue)  for j := 1; j <= 1000; j++ {    msgQueue <- fmt.Sprintf("msg_%d", j)    time.Sleep(1 * time.Second)  }  close(msgQueue)  return}

運行效果如下:

[root@local t2]# ./logRotateTest1fileName : msg.logrename : msg.log => msg_1.logfileName : msg.logrename : msg_1.log => msg_2.logrename : msg.log => msg_1.logfileName : msg.logrename : msg_2.log => msg_3.logrename : msg_1.log => msg_2.logrename : msg.log => msg_1.logfileName : msg.log^C

討論

這里只是個簡單的示例代碼,實現了log rotate,更多功能需自行開發。

好,就這些了,希望對你有幫助。

以上這篇golang之log rotate詳解就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持VEVB武林網。

 
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
亚洲第一av网| 亚洲精品久久久久久久久久久| 国产极品jizzhd欧美| 538国产精品一区二区免费视频| 伊人一区二区三区久久精品| 51ⅴ精品国产91久久久久久| 国产噜噜噜噜噜久久久久久久久| 欧美日韩裸体免费视频| 精品国产成人在线| 日韩电影免费观看中文字幕| 亚洲国模精品私拍| 成人网在线免费看| 91精品在线播放| 国产精品视频不卡| 日韩在线www| 91久久久久久久久久久| 久久777国产线看观看精品| 国产精品ⅴa在线观看h| 国产人妖伪娘一区91| 97视频在线观看亚洲| 久久精品国产免费观看| 国产精品pans私拍| 欧美日韩国产一中文字不卡| 久久精品国产69国产精品亚洲| 日本中文字幕成人| 奇门遁甲1982国语版免费观看高清| 日韩在线免费观看视频| 色综合久久久久久中文网| 国产精品久久久久久久久久久不卡| 欧美视频免费在线观看| 国产精品日韩欧美| 亚洲国产成人精品久久| 亚洲а∨天堂久久精品喷水| 成年人精品视频| 国产一区视频在线播放| 国产精品久久久久高潮| 亚洲香蕉成人av网站在线观看| 国产精品综合不卡av| 日韩av免费看| 国产成人精彩在线视频九色| 国产精品91久久| 亚洲最大的成人网| 91精品视频大全| 亚洲黄色成人网| 国产精品久久久久999| 国产免费一区二区三区香蕉精| 国产视频自拍一区| 国产精品18久久久久久首页狼| 日本一欧美一欧美一亚洲视频| 日韩美女在线观看一区| 亚洲国产中文字幕久久网| 久久亚洲影音av资源网| 欧美激情精品久久久久久大尺度| 亚洲欧美日韩一区二区三区在线| 中文字幕视频在线免费欧美日韩综合在线看| 国产免费一区二区三区在线观看| 秋霞av国产精品一区| 国产在线视频2019最新视频| 91久久久久久久| 国产精品亚洲视频在线观看| 亚洲福利小视频| 日韩在线视频播放| 久久国产精品首页| 亚洲黄色有码视频| 日韩中文字幕网| 亚洲精品wwww| 成人精品在线视频| 久久天天躁夜夜躁狠狠躁2022| 91九色视频导航| 疯狂欧美牲乱大交777| 国产精品免费一区二区三区都可以| 日韩欧美亚洲成人| 日韩欧美高清在线视频| 欧美激情一区二区三区高清视频| 国产亚洲精品va在线观看| 日韩在线视频一区| 亚洲日韩欧美视频| 国产91精品青草社区| 欧美日韩福利视频| 亚洲欧洲午夜一线一品| 亚洲国产精品电影| 都市激情亚洲色图| 欧美丰满老妇厨房牲生活| 国产偷亚洲偷欧美偷精品| 日韩黄色在线免费观看| 中文字幕欧美在线| 久久精品一偷一偷国产| 国产热re99久久6国产精品| 久久电影一区二区| 激情懂色av一区av二区av| 国产91|九色| 国产一区二区三区视频| 久久免费国产精品1| 欧美另类极品videosbest最新版本| 午夜精品免费视频| 神马久久久久久| 性色av香蕉一区二区| 黄色精品一区二区| 国产精品中文在线| 久久久久久久久久国产精品| 国模视频一区二区三区| 97视频在线免费观看| 国产一区二区美女视频| 久色乳综合思思在线视频| 亚洲夜晚福利在线观看| www.久久草.com| 成人免费视频网| 国产一区二区三区在线视频| 亚洲激情视频在线播放| 久久久视频精品| 国产精品69av| 欧美国产精品人人做人人爱| 亚洲xxx视频| 欧美孕妇性xx| 欧美高清视频一区二区| yellow中文字幕久久| 欧美电影《睫毛膏》| 久久精品99国产精品酒店日本| 亚洲精品国产精品自产a区红杏吧| 欧美高清视频一区二区| 欧美电影在线观看高清| 91精品中文在线| 97国产在线视频| 久久久久久免费精品| 日韩av在线高清| 亚洲欧美一区二区三区在线| 亚洲女人被黑人巨大进入| 国产精品久久色| 亚洲男人天堂九九视频| 中文字幕日韩精品在线观看| 亚洲无限av看| 国产精品视频xxxx| 懂色aⅴ精品一区二区三区蜜月| 久久精品国产免费观看| 日韩激情片免费| 羞羞色国产精品| 欧美午夜精品久久久久久人妖| 日韩免费在线电影| 精品国产欧美一区二区三区成人| 国产日韩一区在线| 91精品国产高清久久久久久| 亚洲成人激情在线| 大量国产精品视频| 奇门遁甲1982国语版免费观看高清| 久久久欧美精品| 浅井舞香一区二区| 亚洲色图色老头| 日韩一区二区在线视频| 影音先锋欧美在线资源| 欧美日韩精品在线| 亚洲色图校园春色| 国产丝袜一区二区三区免费视频| 久久久久久噜噜噜久久久精品| 国产一区二区三区18| 九九热这里只有在线精品视| 一区二区三区回区在观看免费视频| 亚洲激情小视频| 夜夜嗨av色一区二区不卡| 亚洲视频在线播放| 久久久久久成人| 久久免费国产精品1| 亚洲激情成人网| 久久久久免费精品国产| 亚洲欧美中文日韩在线v日本|