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 中断 仅输出内容
适用场景 正式日志记录 临时调试输出

相关推荐
研究司马懿1 天前
【云原生】Gateway API高级功能
云原生·go·gateway·k8s·gateway api
梦想很大很大2 天前
使用 Go + Gin + Fx 构建工程化后端服务模板(gin-app 实践)
前端·后端·go
lekami_兰2 天前
MySQL 长事务:藏在业务里的性能 “隐形杀手”
数据库·mysql·go·长事务
却尘2 天前
一篇小白也能看懂的 Go 字符串拼接 & Builder & cap 全家桶
后端·go
ん贤2 天前
一次批量删除引发的死锁,最终我选择不加锁
数据库·安全·go·死锁
mtngt112 天前
AI DDD重构实践
go
Grassto4 天前
12 go.sum 是如何保证依赖安全的?校验机制源码解析
安全·golang·go·哈希算法·go module
Grassto6 天前
11 Go Module 缓存机制详解
开发语言·缓存·golang·go·go module
程序设计实验室7 天前
2025年的最后一天,分享我使用go语言开发的电子书转换工具网站
go
我的golang之路果然有问题7 天前
使用 Hugo + GitHub Pages + PaperMod 主题 + Obsidian 搭建开发博客
golang·go·github·博客·个人开发·个人博客·hugo