logs.go 1.8 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091
  1. package logger
  2. import (
  3. "fmt"
  4. "io"
  5. "log"
  6. "os"
  7. "github.com/sirupsen/logrus"
  8. )
  9. //var Logger *logrus.Logger
  10. type Hook struct {
  11. Writer io.Writer
  12. Formatter logrus.Formatter
  13. Level []logrus.Level
  14. }
  15. func (h *Hook) Fire(entry *logrus.Entry) error {
  16. line, err := h.Formatter.Format(entry)
  17. if err != nil {
  18. return err
  19. }
  20. h.Writer.Write(line)
  21. return nil
  22. }
  23. func (h *Hook) Levels() []logrus.Level {
  24. return h.Level
  25. }
  26. func newHook(writer io.Writer, formatter logrus.Formatter, level logrus.Level) *Hook {
  27. var levels []logrus.Level
  28. for _, l := range logrus.AllLevels {
  29. if l <= level {
  30. levels = append(levels, l)
  31. }
  32. }
  33. return &Hook{
  34. Writer: writer,
  35. Formatter: formatter,
  36. Level: levels,
  37. }
  38. }
  39. func Init(logFilePath string, logLevelStr string) *logrus.Logger {
  40. dir := "./logs/"
  41. // 检查目录是否存在
  42. if _, err := os.Stat(dir); os.IsNotExist(err) {
  43. // 目录不存在,创建目录
  44. err := os.MkdirAll(dir, os.ModePerm)
  45. if err != nil {
  46. fmt.Println("Error creating directory:", err)
  47. return nil
  48. }
  49. fmt.Println("Directory created:", dir)
  50. }
  51. var Logger *logrus.Logger
  52. logLevel, err := logrus.ParseLevel(logLevelStr)
  53. if err != nil {
  54. logLevel = logrus.InfoLevel
  55. log.Printf("Invalid log level: %s. Defaulting to info", logLevelStr)
  56. }
  57. Logger = logrus.New()
  58. Logger.SetOutput(io.Discard)
  59. logFile, err := os.OpenFile(logFilePath, os.O_CREATE|os.O_WRONLY|os.O_APPEND, 0644)
  60. if err != nil {
  61. log.Printf("Failed to open log file: %s", logFilePath)
  62. panic(err)
  63. }
  64. Logger.AddHook(newHook(
  65. logFile,
  66. &logrus.JSONFormatter{},
  67. logLevel,
  68. ))
  69. Logger.AddHook(newHook(
  70. os.Stderr,
  71. &logrus.TextFormatter{
  72. FullTimestamp: true,
  73. ForceColors: true,
  74. },
  75. logLevel,
  76. ))
  77. return Logger
  78. }