fix: setup logger
This commit is contained in:
@@ -4,9 +4,7 @@ import (
|
|||||||
"fmt"
|
"fmt"
|
||||||
"gpt-load/internal/models"
|
"gpt-load/internal/models"
|
||||||
"gpt-load/internal/types"
|
"gpt-load/internal/types"
|
||||||
"io"
|
|
||||||
"os"
|
"os"
|
||||||
"path/filepath"
|
|
||||||
"reflect"
|
"reflect"
|
||||||
"strconv"
|
"strconv"
|
||||||
"strings"
|
"strings"
|
||||||
@@ -163,44 +161,3 @@ func GetEnvOrDefault(key, defaultValue string) string {
|
|||||||
}
|
}
|
||||||
return defaultValue
|
return defaultValue
|
||||||
}
|
}
|
||||||
|
|
||||||
// SetupLogger configures the logging system based on the provided configuration.
|
|
||||||
func SetupLogger(configManager types.ConfigManager) {
|
|
||||||
logConfig := configManager.GetLogConfig()
|
|
||||||
|
|
||||||
// Set log level
|
|
||||||
level, err := logrus.ParseLevel(logConfig.Level)
|
|
||||||
if err != nil {
|
|
||||||
logrus.Warn("Invalid log level, using info")
|
|
||||||
level = logrus.InfoLevel
|
|
||||||
}
|
|
||||||
logrus.SetLevel(level)
|
|
||||||
|
|
||||||
// Set log format
|
|
||||||
if logConfig.Format == "json" {
|
|
||||||
logrus.SetFormatter(&logrus.JSONFormatter{
|
|
||||||
TimestampFormat: "2006-01-02T15:04:05.000Z07:00", // ISO 8601 format
|
|
||||||
})
|
|
||||||
} else {
|
|
||||||
logrus.SetFormatter(&logrus.TextFormatter{
|
|
||||||
ForceColors: true,
|
|
||||||
FullTimestamp: true,
|
|
||||||
TimestampFormat: "2006-01-02 15:04:05",
|
|
||||||
})
|
|
||||||
}
|
|
||||||
|
|
||||||
// Setup file logging if enabled
|
|
||||||
if logConfig.EnableFile {
|
|
||||||
logDir := filepath.Dir(logConfig.FilePath)
|
|
||||||
if err := os.MkdirAll(logDir, 0755); err != nil {
|
|
||||||
logrus.Warnf("Failed to create log directory: %v", err)
|
|
||||||
} else {
|
|
||||||
logFile, err := os.OpenFile(logConfig.FilePath, os.O_CREATE|os.O_WRONLY|os.O_APPEND, 0666)
|
|
||||||
if err != nil {
|
|
||||||
logrus.Warnf("Failed to open log file: %v", err)
|
|
||||||
} else {
|
|
||||||
logrus.SetOutput(io.MultiWriter(os.Stdout, logFile))
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
51
internal/utils/logger_utils.go
Normal file
51
internal/utils/logger_utils.go
Normal file
@@ -0,0 +1,51 @@
|
|||||||
|
package utils
|
||||||
|
|
||||||
|
import (
|
||||||
|
"gpt-load/internal/types"
|
||||||
|
"io"
|
||||||
|
"os"
|
||||||
|
"path/filepath"
|
||||||
|
|
||||||
|
"github.com/sirupsen/logrus"
|
||||||
|
)
|
||||||
|
|
||||||
|
// SetupLogger configures the logging system based on the provided configuration.
|
||||||
|
func SetupLogger(configManager types.ConfigManager) {
|
||||||
|
logConfig := configManager.GetLogConfig()
|
||||||
|
|
||||||
|
// Set log level
|
||||||
|
level, err := logrus.ParseLevel(logConfig.Level)
|
||||||
|
if err != nil {
|
||||||
|
logrus.Warn("Invalid log level, using info")
|
||||||
|
level = logrus.InfoLevel
|
||||||
|
}
|
||||||
|
logrus.SetLevel(level)
|
||||||
|
|
||||||
|
// Set log format
|
||||||
|
if logConfig.Format == "json" {
|
||||||
|
logrus.SetFormatter(&logrus.JSONFormatter{
|
||||||
|
TimestampFormat: "2006-01-02T15:04:05.000Z07:00", // ISO 8601 format
|
||||||
|
})
|
||||||
|
} else {
|
||||||
|
logrus.SetFormatter(&logrus.TextFormatter{
|
||||||
|
ForceColors: true,
|
||||||
|
FullTimestamp: true,
|
||||||
|
TimestampFormat: "2006-01-02 15:04:05",
|
||||||
|
})
|
||||||
|
}
|
||||||
|
|
||||||
|
// Setup file logging if enabled
|
||||||
|
if logConfig.EnableFile {
|
||||||
|
logDir := filepath.Dir(logConfig.FilePath)
|
||||||
|
if err := os.MkdirAll(logDir, 0755); err != nil {
|
||||||
|
logrus.Warnf("Failed to create log directory: %v", err)
|
||||||
|
} else {
|
||||||
|
logFile, err := os.OpenFile(logConfig.FilePath, os.O_CREATE|os.O_WRONLY|os.O_APPEND, 0666)
|
||||||
|
if err != nil {
|
||||||
|
logrus.Warnf("Failed to open log file: %v", err)
|
||||||
|
} else {
|
||||||
|
logrus.SetOutput(io.MultiWriter(os.Stdout, logFile))
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
4
main.go
4
main.go
@@ -10,10 +10,10 @@ import (
|
|||||||
"time"
|
"time"
|
||||||
|
|
||||||
"gpt-load/internal/app"
|
"gpt-load/internal/app"
|
||||||
"gpt-load/internal/config"
|
|
||||||
"gpt-load/internal/container"
|
"gpt-load/internal/container"
|
||||||
"gpt-load/internal/models"
|
"gpt-load/internal/models"
|
||||||
"gpt-load/internal/types"
|
"gpt-load/internal/types"
|
||||||
|
"gpt-load/internal/utils"
|
||||||
|
|
||||||
"github.com/sirupsen/logrus"
|
"github.com/sirupsen/logrus"
|
||||||
)
|
)
|
||||||
@@ -47,7 +47,7 @@ func main() {
|
|||||||
|
|
||||||
// Initialzie global logger
|
// Initialzie global logger
|
||||||
if err := container.Invoke(func(configManager types.ConfigManager) {
|
if err := container.Invoke(func(configManager types.ConfigManager) {
|
||||||
config.SetupLogger(configManager)
|
utils.SetupLogger(configManager)
|
||||||
}); err != nil {
|
}); err != nil {
|
||||||
logrus.Fatalf("Failed to setup logger: %v", err)
|
logrus.Fatalf("Failed to setup logger: %v", err)
|
||||||
}
|
}
|
||||||
|
Reference in New Issue
Block a user