golang之log rotate

来源:http://www.cnblogs.com/MikeZhang/archive/2017/06/14/golangLogRotate20170614.html
-Advertisement-
Play Games

操作系統: CentOS 6.9_x64 go語言版本: 1.8.3 問題描述 golang的log模塊提供的有寫日誌功能,示例代碼如下: 運行效果: go語言的log模塊沒有提供log rotate介面,但實際開發中我們需要該功能: 我們不希望單個日誌過大,否則文本編輯器無法打開,查看比較困難; ...


操作系統: CentOS 6.9_x64

go語言版本: 1.8.3

問題描述

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

/*
golang log example
E-Mail : [email protected]
*/
package main

import (
    "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
    E-Mail : [email protected]
*/

package main

import (
    "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]# ./logRotateTest1
fileName : msg.log
rename :  msg.log  =>  msg_1.log
fileName : msg.log
rename :  msg_1.log  =>  msg_2.log
rename :  msg.log  =>  msg_1.log
fileName : msg.log
rename :  msg_2.log  =>  msg_3.log
rename :  msg_1.log  =>  msg_2.log
rename :  msg.log  =>  msg_1.log
fileName : msg.log
^C

討論

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

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

本文github地址:

https://github.com/mike-zhang/mikeBlogEssays/blob/master/2017/20170614_golang之logRotate.rst

歡迎補充 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 經過我三篇文章的解惑,webapi我相信大家沒有問題了! 先創建了一個UserModel 然後添加Web API Controller 註冊路由 在Global中註冊 這個時候用地址欄訪問地址:api/user/getadmin 這個時侯預設返回的是XML數據模型。 使用AJAX請求這個api,指定 ...
  • 由於公司的工作安排,一直在研究其他技術,所以一直沒時間更新博客,今天終於可以停下手頭的事情,寫一些新內容了。 應用場景:企業門戶網站會根據內容不同,設置不同的板塊,如新浪有體育,娛樂頻道,等等。有的情況下需要給不同的板塊設置不同的二級功能變數名稱,如新浪體育sports.sina.com.cn。 在asp. ...
  • 大學畢業已三年,菜鳥稱謂依然。畢業前使用過六個月的MVC,但是自從畢業後因為公司一直在用webForm,所以MVC就沒有再用過。直到最近打算用MVC做一個項目管理系統,才發現MVC已經變得陌生了,只有再從新學起。為了防止自己的拖延症拖延自己的學習計劃,特在博客園寫此文。學習期間,所有的感悟和整理的可 ...
  • 這個項目深刻的為我們講解了pc客戶端如何請求webapi 相信大家在看了我轉載的第一篇文章和這篇文章之後,對webapi再也不會懼怕了! 討論webapi的知識,歡迎加我微信 jkxx123321 交流 WCF的野心造成了它的龐大複雜,HTTP的單純造就了它的簡單優美。為了實現分散式Web應用,我們 ...
  • 使用Composition API實現Pivot中多個頁吸頂。 ...
  • Expression Expand 字元串展開問題,按照[]前的數字展開字元串,主要是維護兩個棧一個是展開個數棧一個是展開內容棧,內容棧添加[用來判斷是否把要展開的內容全部推出,然後要註意數字可能不止一位其他就無所謂了 ...
  • 1、先說結論:使用xml-rpc的機制可以很方便的實現伺服器間的RPC調用。 2、試驗結果如下: 3、源碼如下: 伺服器端的源代碼如下: 客戶端的代碼如下: ...
  • 下載Python對應版本的py2exe,使用這個工具可以將自己的程式打包成exe文件。使用這個工具需要寫一個用於打包的setup.py文件(名稱可以自己定,不一定是setup.py),寫好後在命令提示符界面cd到這個文件的目錄,執行命令“python setup.py py2exe”即可打包完成。下... ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...