logger.go 2.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100
  1. package common
  2. import (
  3. "context"
  4. "fmt"
  5. "github.com/gin-gonic/gin"
  6. "io"
  7. "log"
  8. "os"
  9. "path/filepath"
  10. "sync"
  11. "time"
  12. )
  13. const (
  14. loggerINFO = "INFO"
  15. loggerWarn = "WARN"
  16. loggerError = "ERR"
  17. )
  18. const maxLogCount = 1000000
  19. var logCount int
  20. var setupLogLock sync.Mutex
  21. var setupLogWorking bool
  22. func SetupLogger() {
  23. if *LogDir != "" {
  24. ok := setupLogLock.TryLock()
  25. if !ok {
  26. log.Println("setup log is already working")
  27. return
  28. }
  29. defer func() {
  30. setupLogLock.Unlock()
  31. setupLogWorking = false
  32. }()
  33. logPath := filepath.Join(*LogDir, fmt.Sprintf("oneapi-%s.log", time.Now().Format("20060102")))
  34. fd, err := os.OpenFile(logPath, os.O_APPEND|os.O_CREATE|os.O_WRONLY, 0644)
  35. if err != nil {
  36. log.Fatal("failed to open log file")
  37. }
  38. gin.DefaultWriter = io.MultiWriter(os.Stdout, fd)
  39. gin.DefaultErrorWriter = io.MultiWriter(os.Stderr, fd)
  40. }
  41. }
  42. func SysLog(s string) {
  43. t := time.Now()
  44. _, _ = fmt.Fprintf(gin.DefaultWriter, "[SYS] %v | %s \n", t.Format("2006/01/02 - 15:04:05"), s)
  45. }
  46. func SysError(s string) {
  47. t := time.Now()
  48. _, _ = fmt.Fprintf(gin.DefaultErrorWriter, "[SYS] %v | %s \n", t.Format("2006/01/02 - 15:04:05"), s)
  49. }
  50. func LogInfo(ctx context.Context, msg string) {
  51. logHelper(ctx, loggerINFO, msg)
  52. }
  53. func LogWarn(ctx context.Context, msg string) {
  54. logHelper(ctx, loggerWarn, msg)
  55. }
  56. func LogError(ctx context.Context, msg string) {
  57. logHelper(ctx, loggerError, msg)
  58. }
  59. func logHelper(ctx context.Context, level string, msg string) {
  60. writer := gin.DefaultErrorWriter
  61. if level == loggerINFO {
  62. writer = gin.DefaultWriter
  63. }
  64. id := ctx.Value(RequestIdKey)
  65. now := time.Now()
  66. _, _ = fmt.Fprintf(writer, "[%s] %v | %s | %s \n", level, now.Format("2006/01/02 - 15:04:05"), id, msg)
  67. logCount++ // we don't need accurate count, so no lock here
  68. if logCount > maxLogCount && !setupLogWorking {
  69. logCount = 0
  70. setupLogWorking = true
  71. go func() {
  72. SetupLogger()
  73. }()
  74. }
  75. }
  76. func FatalLog(v ...any) {
  77. t := time.Now()
  78. _, _ = fmt.Fprintf(gin.DefaultErrorWriter, "[FATAL] %v | %v \n", t.Format("2006/01/02 - 15:04:05"), v)
  79. os.Exit(1)
  80. }
  81. func LogQuota(quota int) string {
  82. if DisplayInCurrencyEnabled {
  83. return fmt.Sprintf("$%.6f 额度", float64(quota)/QuotaPerUnit)
  84. } else {
  85. return fmt.Sprintf("%d 点额度", quota)
  86. }
  87. }