feat: create new log file when too many logs recorded
This commit is contained in:
parent
fe26a1448d
commit
4335f005a6
@ -8,6 +8,7 @@ import (
|
|||||||
"log"
|
"log"
|
||||||
"os"
|
"os"
|
||||||
"path/filepath"
|
"path/filepath"
|
||||||
|
"sync"
|
||||||
"time"
|
"time"
|
||||||
)
|
)
|
||||||
|
|
||||||
@ -17,9 +18,24 @@ const (
|
|||||||
loggerError = "ERR"
|
loggerError = "ERR"
|
||||||
)
|
)
|
||||||
|
|
||||||
func SetupGinLog() {
|
const maxLogCount = 1000000
|
||||||
|
|
||||||
|
var logCount int
|
||||||
|
var setupLogLock sync.Mutex
|
||||||
|
var setupLogWorking bool
|
||||||
|
|
||||||
|
func SetupLogger() {
|
||||||
if *LogDir != "" {
|
if *LogDir != "" {
|
||||||
logPath := filepath.Join(*LogDir, fmt.Sprintf("oneapi-%s.log", time.Now().Format("20060102150405")))
|
ok := setupLogLock.TryLock()
|
||||||
|
if !ok {
|
||||||
|
log.Println("setup log is already working")
|
||||||
|
return
|
||||||
|
}
|
||||||
|
defer func() {
|
||||||
|
setupLogLock.Unlock()
|
||||||
|
setupLogWorking = false
|
||||||
|
}()
|
||||||
|
logPath := filepath.Join(*LogDir, fmt.Sprintf("oneapi-%s.log", time.Now().Format("20060102")))
|
||||||
fd, err := os.OpenFile(logPath, os.O_APPEND|os.O_CREATE|os.O_WRONLY, 0644)
|
fd, err := os.OpenFile(logPath, os.O_APPEND|os.O_CREATE|os.O_WRONLY, 0644)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
log.Fatal("failed to open log file")
|
log.Fatal("failed to open log file")
|
||||||
@ -59,6 +75,14 @@ func logHelper(ctx context.Context, level string, msg string) {
|
|||||||
id := ctx.Value(RequestIdKey)
|
id := ctx.Value(RequestIdKey)
|
||||||
now := time.Now()
|
now := time.Now()
|
||||||
_, _ = fmt.Fprintf(writer, "[%s] %v | %s | %s \n", level, now.Format("2006/01/02 - 15:04:05"), id, msg)
|
_, _ = fmt.Fprintf(writer, "[%s] %v | %s | %s \n", level, now.Format("2006/01/02 - 15:04:05"), id, msg)
|
||||||
|
logCount++ // we don't need accurate count, so no lock here
|
||||||
|
if logCount > maxLogCount && !setupLogWorking {
|
||||||
|
logCount = 0
|
||||||
|
setupLogWorking = true
|
||||||
|
go func() {
|
||||||
|
SetupLogger()
|
||||||
|
}()
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
func FatalLog(v ...any) {
|
func FatalLog(v ...any) {
|
||||||
|
2
main.go
2
main.go
@ -21,7 +21,7 @@ var buildFS embed.FS
|
|||||||
var indexPage []byte
|
var indexPage []byte
|
||||||
|
|
||||||
func main() {
|
func main() {
|
||||||
common.SetupGinLog()
|
common.SetupLogger()
|
||||||
common.SysLog("One API " + common.Version + " started")
|
common.SysLog("One API " + common.Version + " started")
|
||||||
if os.Getenv("GIN_MODE") != "debug" {
|
if os.Getenv("GIN_MODE") != "debug" {
|
||||||
gin.SetMode(gin.ReleaseMode)
|
gin.SetMode(gin.ReleaseMode)
|
||||||
|
Loading…
Reference in New Issue
Block a user