首页 > 后端开发 > Golang > 正文

Golang log日志记录与管理示例

P粉602998670
发布: 2025-09-26 22:04:01
原创
489人浏览过
答案:Go语言通过标准库log包实现基础日志功能,支持自定义前缀、时间戳和输出文件;通过创建多个Logger实例可实现Debug、Info、Warn、Error级别管理;结合zap等第三方库可提升性能与结构化能力,适用于生产环境。

golang log日志记录与管理示例

在Go语言开发中,日志是调试、监控和排查问题的重要工具。Golang标准库中的 log 包提供了基础的日志功能,结合第三方库或自定义配置可以实现更灵活的日志管理。以下是一个实用的Golang日志记录与管理示例,涵盖基本用法、输出格式、文件写入和分级管理。

使用标准库 log 输出基础日志

Go 的 log 包支持输出到控制台或文件,并可添加时间戳等前缀信息。

package main

import (
    "log"
    "os"
)

func main() {
    // 设置日志前缀和标志(包含日期和时间)
    log.SetPrefix("[INFO] ")
    log.SetFlags(log.Ldate | log.Ltime | log.Lshortfile)

    log.Println("程序启动")
    log.Printf("处理了 %d 个请求", 100)
}
登录后复制

运行后输出类似:

[INFO] 2023/04/05 10:20:30 main.go:12: 程序启动
[INFO] 2023/04/05 10:20:30 main.go:13: 处理了 100 个请求
登录后复制

将日志写入文件

默认情况下,log 输出到标准错误。可通过 log.SetOutput() 将日志重定向到文件。

立即学习go语言免费学习笔记(深入)”;

file, err := os.OpenFile("app.log", os.O_CREATE|os.O_WRONLY|os.O_APPEND, 0666)
if err != nil {
    log.Fatal("无法打开日志文件:", err)
}
defer file.Close()

// 设置日志输出到文件
log.SetOutput(file)
log.Println("这将写入 app.log 文件")
登录后复制

这样所有日志都会追加写入指定文件,适合长期运行的服务。

Get笔记
Get笔记

Get笔记,一款AI驱动的知识管理产品

Get笔记125
查看详情 Get笔记

实现日志分级(Debug、Info、Warn、Error)

标准库 log 不直接支持分级,但可通过创建多个 logger 实现。

debugLog := log.New(os.Stdout, "[DEBUG] ", log.LstdFlags)
infoLog := log.New(os.Stdout, "[INFO ] ", log.LstdFlags)
warnLog := log.New(os.Stdout, "[WARN ] ", log.LstdFlags)
errorLog := log.New(os.Stderr, "[ERROR] ", log.LstdFlags)

debugLog.Println("调试信息")
infoLog.Println("普通信息")
warnLog.Println("警告信息")
errorLog.Println("错误信息")
登录后复制

不同级别的日志可分别输出到不同目标,例如错误日志单独写入 error.log。

使用第三方库(如 zap 或 logrus)提升性能和功能

对于高并发服务,推荐使用 uber-go/zap 这类高性能结构化日志库。

import "go.uber.org/zap"

func main() {
    logger, _ := zap.NewProduction()
    defer logger.Sync()

    logger.Info("用户登录",
        zap.String("user", "alice"),
        zap.Int("id", 1001),
    )
}
登录后复制

zap 支持 JSON 格式输出、字段结构化、日志级别控制和高效写入,适合生产环境。

基本上就这些。从标准库入门,按需引入分级管理和高性能库,能有效支撑项目日志需求。

以上就是Golang log日志记录与管理示例的详细内容,更多请关注php中文网其它相关文章!

最佳 Windows 性能的顶级免费优化软件
最佳 Windows 性能的顶级免费优化软件

每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习
PHP中文网抖音号
发现有趣的

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号