package log                                                                                                                                                                                                 

import (
    "log"
    "os"
    "time"
)

var (
    debug_log  = "debug.log"
    log_format = "2006-01-02-15"
)

var fileHandle *os.File
var cs chan string

func init() {
    file_name := getFileName()
    fileHandle, _ = os.OpenFile(file_name, os.O_RDWR|os.O_CREATE|os.O_APPEND, 0755)
    log.SetOutput(fileHandle)
    cs = make(chan string, 1024)
    go WriteChan(cs)

}

func getFileName() string {
    now := time.Now()
    date := now.Format(log_format)
    file_path := "/your/local/dir/"
    filename := file_path + debug_log + "." + date

    return filename
}

func WriteDebugLog(content string) {

    //check log file
    curFileName := getFileName()

    if _, err := os.Stat(curFileName); os.IsNotExist(err) {
        file_name := getFileName()
        fileHandle, _ = os.OpenFile(file_name, os.O_RDWR|os.O_CREATE|os.O_APPEND, 0755)
        log.SetOutput(fileHandle)
    }   
    //WriteSingleLog(content)
    cs <- content
}

func WriteChan(cs chan string) {
    for {
        select {
        case con := <-cs:
            WriteSingleLog(con)
            //beego.Debug(len(cs))
        }
    }
}

func WriteSingleLog(content string) {
    log.Println(content)
}          

  

相关文章:

  • 2022-12-23
  • 2022-12-23
  • 2021-10-01
  • 2022-12-23
  • 2021-12-09
  • 2021-07-10
  • 2022-12-23
  • 2022-01-30
猜你喜欢
  • 2021-06-19
  • 2022-02-15
  • 2021-10-30
  • 2022-12-23
  • 2022-12-23
  • 2022-12-23
相关资源
相似解决方案