20 Star 167 Fork 29

qiqi/orange

加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
文件
克隆/下载
stream.go 1.27 KB
一键复制 编辑 原始数据 按行查看 历史
qiqi 提交于 2020-11-27 12:53 . 日志写入问题修复
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
}
Loading...
马建仓 AI 助手
尝试更多
代码解读
代码找茬
代码优化
Go
1
https://gitee.com/zhucheer/orange.git
git@gitee.com:zhucheer/orange.git
zhucheer
orange
orange
v0.5.18

搜索帮助