0

0

如何使用Golang实现日志系统_结合log包记录文件和控制台日志

P粉602998670

P粉602998670

发布时间:2025-12-29 10:57:53

|

671人浏览过

|

来源于php中文网

原创

Go标准库log包默认仅输出到stderr,需用io.MultiWriter实现文件与控制台双输出,并通过SetFlags、SetPrefix或自定义Logger添加时间戳、级别前缀及ISO8601格式;封装Info/Warning/Error方法可模拟日志级别,生产环境建议加bufio缓冲和定时轮转。

如何使用golang实现日志系统_结合log包记录文件和控制台日志

Go 标准库log 包轻量、易用,但默认只输出到标准错误(stderr),不支持同时写文件和控制台,也不带日志级别、格式化时间等常用功能。要实现“文件 + 控制台”双输出日志系统,核心思路是:用 io.MultiWriter 将日志同时写入多个 io.Writer(如文件和 os.Stdout),再配合自定义格式器提升可读性。

基础双输出:用 MultiWriter 同时写文件和控制台

Go 的 log.SetOutput() 只接受一个 io.Writer,但我们可以用 io.MultiWriter 把多个 writer 合并成一个:

  • 先创建日志文件(如 app.log),用 os.OpenFile 打开,设置 os.O_CREATE | os.O_APPEND | os.O_WRONLY
  • 调用 io.MultiWriter(file, os.Stdout) 构造组合 writer
  • 传给 log.SetOutput(),后续所有 log.Print/Printf/Println 都会同步输出到两者

注意:文件需手动关闭,建议在程序退出前用 defer file.Close();若需按天轮转,需自行判断日期并重建文件句柄。

增强可读性:自定义日志前缀和时间格式

默认日志不带时间戳或模块标识,不利于排查。可通过 log.SetFlags()log.SetPrefix() 快速改进:

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

大师兄智慧家政
大师兄智慧家政

58到家打造的AI智能营销工具

下载
  • log.SetFlags(log.LstdFlags | log.Lshortfile):启用标准时间 + 文件名+行号(LstdFlags 含日期、时间、微秒)
  • log.SetPrefix("[INFO] "):为每条日志加统一前缀(如 "[INFO]"、"[ERROR]")
  • 若需更灵活的时间格式(如 ISO8601),需封装自己的 Logger,用 time.Now().Format("2006-01-02 15:04:05") 拼接字符串后调用 log.Print()

区分日志级别:封装 Info/Warning/Error 方法

标准 log 包无级别概念,但可通过封装实现语义化调用:

  • 定义三个全局 *log.Logger 实例:分别设置不同前缀("[INFO] ""[WARN] ""[ERROR] ")和不同输出(例如 error 日志额外写入 os.Stderr
  • 每个实例调用 log.New(multiWriter, prefix, flags) 创建,复用同一底层 writer
  • 对外提供 Infof(msg string, v ...interface{}) 等函数,内部调用对应 logger 的 Printf

这样既保持标准库简洁性,又获得类似第三方库(如 zap、logrus)的使用体验。

生产可用建议:避免阻塞与简单轮转

直接用 os.File 写日志在高并发下可能成为瓶颈,且不支持自动切割。简单但实用的优化方式:

  • 使用 bufio.NewWriterSize(file, 4096) 包装文件 writer,减少系统调用次数
  • 每日轮转可借助定时器(time.Ticker)检查当前日期,变化时关闭旧文件、打开新文件,并更新 MultiWriter 中的 writer(注意线程安全,建议加锁)
  • 关键错误日志(如 panic)建议单独用 log.SetOutput(os.Stderr) 确保不丢失,再恢复原输出

不复杂但容易忽略。

相关专题

更多
golang如何定义变量
golang如何定义变量

golang定义变量的方法:1、声明变量并赋予初始值“var age int =值”;2、声明变量但不赋初始值“var age int”;3、使用短变量声明“age :=值”等等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

173

2024.02.23

golang有哪些数据转换方法
golang有哪些数据转换方法

golang数据转换方法:1、类型转换操作符;2、类型断言;3、字符串和数字之间的转换;4、JSON序列化和反序列化;5、使用标准库进行数据转换;6、使用第三方库进行数据转换;7、自定义数据转换函数。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

224

2024.02.23

golang常用库有哪些
golang常用库有哪些

golang常用库有:1、标准库;2、字符串处理库;3、网络库;4、加密库;5、压缩库;6、xml和json解析库;7、日期和时间库;8、数据库操作库;9、文件操作库;10、图像处理库。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

335

2024.02.23

golang和python的区别是什么
golang和python的区别是什么

golang和python的区别是:1、golang是一种编译型语言,而python是一种解释型语言;2、golang天生支持并发编程,而python对并发与并行的支持相对较弱等等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

206

2024.03.05

golang是免费的吗
golang是免费的吗

golang是免费的。golang是google开发的一种静态强类型、编译型、并发型,并具有垃圾回收功能的开源编程语言,采用bsd开源协议。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

388

2024.05.21

golang结构体相关大全
golang结构体相关大全

本专题整合了golang结构体相关大全,想了解更多内容,请阅读专题下面的文章。

193

2025.06.09

golang相关判断方法
golang相关判断方法

本专题整合了golang相关判断方法,想了解更详细的相关内容,请阅读下面的文章。

184

2025.06.10

golang数组使用方法
golang数组使用方法

本专题整合了golang数组用法,想了解更多的相关内容,请阅读专题下面的文章。

191

2025.06.17

ip地址修改教程大全
ip地址修改教程大全

本专题整合了ip地址修改教程大全,阅读下面的文章自行寻找合适的解决教程。

121

2025.12.26

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Go 教程
Go 教程

共32课时 | 3.1万人学习

Go语言实战之 GraphQL
Go语言实战之 GraphQL

共10课时 | 0.8万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

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