go日志包log

核心功能与接口

  1. 基础日志输出

    • Print 系列 :支持 Print()Println()Printf(),输出日志不中断程序。

      c 复制代码
      log.Print("常规日志")          // 输出: 2025/03/18 14:47:13 常规日志 
      log.Printf("格式化: %s", "数据") 
    • Fatal 系列 :调用后触发 os.Exit(1) 终止程序,不会执行 defer 函数

      c 复制代码
      log.Fatal("严重错误") // 输出日志并退出 
    • Panic 系列 :输出日志后触发 panic(),可通过 recover() 捕获。

      go 复制代码
      defer func() { if err := recover(); err != nil {} }()
      log.Panic("触发崩溃")
  2. 预定义 Logger

    • 默认使用 log.Stdout 输出到控制台,可通过 log.SetOutput() 重定向到文件或网络。

配置与定制

  1. 设置日志前缀

    • log.SetPrefix("APP: ") 添加固定前缀,如 APP: 2025/03/18 14:47:13 日志内容
  2. 调整日志格式

    • 通过 log.SetFlags() 组合标志位控制输出内容:

      c 复制代码
      log.SetFlags(log.Ldate | log.Ltime | log.Lshortfile)
      // 输出示例: 2025/03/18 14:47:13 main.go:10:  日志内容 
      • 常用标志:Ldate(日期)、Ltime(时间)、Lmicroseconds(微秒)、Llongfile(完整文件路径)、LUTC(UTC 时间)。
  3. 自定义 Logger 对象

    • 使用 log.New() 创建独立 Logger,支持多目标输出:

      lua 复制代码
      var (
          DebugLog = log.New(os.Stdout, "DEBUG: ", 
              log.Ldate|log.Ltime|log.Lshortfile)
          InfoLog  = log.New(os.Stdout, "INFO: ", 
              log.Ldate|log.Ltime)
          ErrorLog = log.New(os.Stderr, "ERROR: ", 
              log.Ldate|log.Ltime|log.Llongfile)
      )
      
      func main() {
          DebugLog.Println("调试信息")  
      // DEBUG: 2023/10/01 12:00:00 /path/main.go:15
          InfoLog.Printf("用户登录: %s", "user123") 
      // INFO: 2023/10/01 12:00:00 用户登录: user123
          ErrorLog.Fatal("数据库连接失败") 
      // ERROR: 2023/10/01 12:00:00 /path/main.go:18 
      }
    lua 复制代码
    // 输出到文件
    file, err := os.OpenFile("app.log", os.O_CREATE|os.O_WRONLY|os.O_APPEND, 0644)
    if err != nil {
        log.Fatal("打开文件失败:", err)
    }
    defer file.Close()
    
    // 设置全局日志输出
    log.SetOutput(file)
    
    // 同时输出到文件和标准错误
    multiWriter := io.MultiWriter(file, os.Stderr)
    log.SetOutput(multiWriter)
    • log.SetOutput(io.Discard) 关闭日志

与 fmt 包的差异

特性 log fmt
输出目标 默认 stderr,可自定义(文件/网络) 默认 stdout
时间戳 支持自动添加
并发安全 是(内置互斥锁)
程序中断 支持 Fatal/Panic 中断 仅输出内容
适用场景 正式日志记录 临时调试输出

相关推荐
用户6757049885021 天前
你知道 Go 结构体和结构体指针调用的区别吗?一文带你彻底搞懂!
后端·go
唐青枫1 天前
别把泛型写复杂了:Go generic 从类型参数到实战封装
go
GetcharZp2 天前
告别OOM!用Go+libvips实现30000×50000超大图片的流式瓦片服务
后端·go
妙码生花5 天前
从 PHP 到 AI + Golang,程序员自救转型手记(八):设计管理员模型、热重载配置
前端·后端·go
tyung6 天前
Go 手写 Wait-Free MPSC 无界队列:SwapPointer 实现多生产者无锁入队
后端·go
陈明勇6 天前
Go 1.26 新特性回顾:语言增强、工具升级与 Green Tea GC 默认启用
后端·go
妙码生花7 天前
从 PHP 到 AI + Golang,程序员自救转型手记(二):目录结构、初始化 GIT、设计并开发配置系统
前端·后端·go
leeyi7 天前
Deer-Go:字节 Deer-Flow 的 Go 移植,深度研究 Agent 全拆解
go·aigc·agent
Bolt8 天前
TypeScript 7.0 来了:当 tsc 用 Go 重写之后
javascript·typescript·go
Go_error8 天前
Datatypes:Go 轻松支持数据库JSON类型
后端·go