代码拉取完成,页面将自动刷新
package logger
import (
"bytes"
"fmt"
"os"
"sync"
"sync/atomic"
)
// StreamMessageHandler
type StreamMessageHandler struct {
LogDir string
LogFileName string
LogExt string
LogFilePath string
LogBuffer *bytes.Buffer
BufferLine uint64
LogFileHandler *os.File
mutex sync.Mutex
}
var logLineOps uint64 = 0
// Write write log to buffer
func (handler *StreamMessageHandler) Write(message []byte) {
handler.mutex.Lock()
handler.LogBuffer.Write(message)
handler.mutex.Unlock()
atomic.AddUint64(&logLineOps, 1)
// if log buffer line Greater than maximum number of rows, it will sync log
if atomic.LoadUint64(&logLineOps) >= maxLogSyncLine {
handler.SyncLog()
}
}
// SyncLog interval sync log stream buffer
func (handler *StreamMessageHandler) SyncLog() {
handler.mutex.Lock()
defer handler.mutex.Unlock()
if handler.LogBuffer.Len() > 0 {
logLineOps = 0
message := handler.LogBuffer.Bytes()
handler.LogBuffer.Reset()
handler.LogFileHandler.Write(message)
}
}
func openLogFile(logfile string) (logFile *os.File) {
if logfile == "" {
logFile = os.Stdout
return
}
logFile, err := os.OpenFile(logfile, os.O_CREATE|os.O_RDWR|os.O_APPEND, 0666)
if err != nil {
panic(fmt.Sprintf("log file create error: %v", err))
}
return
}
此处可能存在不合适展示的内容,页面不予展示。您可通过相关编辑功能自查并修改。
如您确认内容无涉及 不当用语 / 纯广告导流 / 暴力 / 低俗色情 / 侵权 / 盗版 / 虚假 / 无价值内容或违法国家有关法律法规的内容,可点击提交进行申诉,我们将尽快为您处理。