Files
go-common/docs/logger.md
2025-11-30 13:43:43 +08:00

5.8 KiB
Raw Blame History

日志工具文档

概述

日志工具提供了统一的日志记录功能使用Go标准库实现无需第三方依赖。

功能特性

  • 支持多种日志级别debug, info, warn, error
  • 支持多种输出方式stdout, stderr, file, both
  • 支持日志文件自动创建
  • 支持日志前缀
  • 支持禁用时间戳
  • 支持带字段的日志记录
  • 使用配置工具统一管理配置

使用方法

1. 从配置创建日志记录器(推荐)

import (
    "git.toowon.com/jimmy/go-common/config"
    "git.toowon.com/jimmy/go-common/factory"
)

// 加载配置
cfg, err := config.LoadFromFile("./config.json")
if err != nil {
    log.Fatal(err)
}

// 使用工厂创建日志记录器(已初始化,可直接使用)
fac := factory.NewFactory(cfg)
logger, err := fac.GetLogger()
if err != nil {
    log.Fatal(err)
}

// 直接使用
logger.Info("Application started")
logger.Error("Failed to connect: %v", err)

2. 直接创建日志记录器

import (
    "git.toowon.com/jimmy/go-common/config"
    "git.toowon.com/jimmy/go-common/logger"
)

// 从配置获取日志配置
cfg, _ := config.LoadFromFile("./config.json")
loggerConfig := cfg.GetLogger()

// 创建日志记录器
logger, err := logger.NewLogger(loggerConfig)
if err != nil {
    log.Fatal(err)
}

// 使用默认配置如果loggerConfig为nil
logger, err := logger.NewLogger(nil)

3. 基本日志记录

// 记录不同级别的日志
logger.Debug("Debug message: %s", "debug info")
logger.Info("Info message: %s", "info")
logger.Warn("Warning message: %s", "warning")
logger.Error("Error message: %s", "error")

// 致命错误(会退出程序)
logger.Fatal("Fatal error: %s", "fatal")

// 恐慌错误会触发panic
logger.Panic("Panic error: %s", "panic")

4. 带字段的日志记录

// 记录带字段的日志
fields := map[string]interface{}{
    "user_id": 123,
    "action": "login",
}
logger.Infof(fields, "User logged in")
logger.Errorf(fields, "Failed to process request")

API 参考

NewLogger(cfg *config.LoggerConfig) (*Logger, error)

创建日志记录器。

参数:

  • cfg: 日志配置对象如果为nil使用默认配置

返回: 日志记录器实例和错误信息

(l *Logger) Debug(format string, v ...interface{})

记录调试日志。

(l *Logger) Info(format string, v ...interface{})

记录信息日志。

(l *Logger) Warn(format string, v ...interface{})

记录警告日志。

(l *Logger) Error(format string, v ...interface{})

记录错误日志。

(l *Logger) Fatal(format string, v ...interface{})

记录致命错误日志并退出程序。

(l *Logger) Panic(format string, v ...interface{})

记录恐慌日志并触发panic。

(l *Logger) Debugf(fields map[string]interface{}, format string, v ...interface{})

记录调试日志(带字段)。

(l *Logger) Infof(fields map[string]interface{}, format string, v ...interface{})

记录信息日志(带字段)。

(l *Logger) Warnf(fields map[string]interface{}, format string, v ...interface{})

记录警告日志(带字段)。

(l *Logger) Errorf(fields map[string]interface{}, format string, v ...interface{})

记录错误日志(带字段)。

配置说明

日志配置通过 config.LoggerConfig 提供:

字段 类型 说明 默认值
Level string 日志级别: debug, info, warn, error info
Output string 输出方式: stdout, stderr, file, both stdout
FilePath string 日志文件路径当output为file或both时必需 -
Prefix string 日志前缀 -
DisableTimestamp bool 禁用时间戳 false

配置示例

输出到标准输出

{
  "logger": {
    "level": "info",
    "output": "stdout",
    "prefix": "app"
  }
}

输出到文件

{
  "logger": {
    "level": "debug",
    "output": "file",
    "filePath": "./logs/app.log",
    "prefix": "app"
  }
}

同时输出到标准输出和文件

{
  "logger": {
    "level": "info",
    "output": "both",
    "filePath": "./logs/app.log",
    "prefix": "app",
    "disableTimestamp": false
  }
}

日志级别说明

  • debug: 调试信息,最详细的日志级别
  • info: 一般信息,正常的程序运行信息
  • warn: 警告信息,可能的问题但不影响程序运行
  • error: 错误信息,程序运行中的错误

注意事项

  1. 文件路径

    • 当output为fileboth时,必须提供filePath
    • 日志文件目录会自动创建(如果不存在)
  2. 日志级别

    • 设置为debug时,会记录所有级别的日志
    • 设置为info会记录info、warn、error级别的日志
    • 设置为warn只记录warn和error级别的日志
    • 设置为error只记录error级别的日志
  3. 文件权限

    • 日志文件创建时使用0666权限
    • 目录创建时使用0755权限
  4. 性能考虑

    • 使用标准库log包性能较好
    • 文件输出使用追加模式,不会覆盖已有日志

完整示例

package main

import (
    "git.toowon.com/jimmy/go-common/config"
    "git.toowon.com/jimmy/go-common/factory"
)

func main() {
    // 加载配置
    cfg, err := config.LoadFromFile("./config.json")
    if err != nil {
        log.Fatal(err)
    }

    // 使用工厂创建日志记录器
    fac := factory.NewFactory(cfg)
    logger, err := fac.GetLogger()
    if err != nil {
        log.Fatal(err)
    }

    // 使用日志记录器
    logger.Info("Application started")
    
    // 记录带字段的日志
    logger.Infof(map[string]interface{}{
        "user_id": 123,
        "action": "login",
    }, "User logged in successfully")
    
    logger.Error("An error occurred: %v", err)
}

示例

完整示例请参考 examples/logger_example.go