如何使用Golang log记录不同级别日志_Golang log Println与Fatal示例
技术百科
P粉602998670
发布时间:2026-01-01
浏览: 次 Go 标准库 log 不支持日志级别,仅提供 Print/Fatal/Panic 等函数,无 Info/Warn/Error 分级;需用第三方库(如 logrus、zap)或自行封装前缀式 Logger。
Go 标准库 log 本身不支持日志级别
这是最容易踩的坑:Go 原生 log 包没有 Info、Warn、Error 等分级接口。它只提供 Print、Printf、Println、Fatal、Fatalf、Panic、Panicf 这几组函数,其中只有 Fatal 和 Panic 会终止程序,其余都只是输出——它们在语义上并无级别区分。
如果你看到别人代码里写了 log.Info(...),那一定是用了第三方库(比如 logrus、zap 或 zerolog),不是标准库。
-
log.Println():输出后换行,不退出进程 -
log.Fatal():等价于log.Println()+os.Exit(1),输出后立即终止程序 -
log.Panic():等价于log.Println()+panic(...),触发 panic,可被recover捕获(但一般不这么用)
如何模拟日志级别(轻量方案)
如果不想引入第三方库,又想区分日志用途,常见做法是封装自己的 Logger 类型,用前缀或不同输出目标来区分:
package main
import (
"log"
"os"
)
var (
InfoLogger = log.New(os.Stdout, "[INFO] ", log.Ldate|log.Ltime|log.Lshortfile)
ErrorLogger = log.New(os.Stderr, "[ERROR] ", log.Ldate|log.Ltime|log.Lshortfile)
FatalLogger = log.New(os.Stderr, "[FATAL] ", log.Ldate|log.Ltime|log.Lshortfile)
)
func main() {
InfoLogger.Println("服务启动完成")
ErrorLogger.Printf("数据库连接失败: %v", "timeout")
FatalLogger.Fatal("配置文件不存在,无法继续")
}
注意:log.New 的第三个参数是 flag,常用组合如 log.Ldate | log.Ltime | log.Lshortfile,能帮你快速定位日志来源;不要漏掉 |,写成逗号会编译失败。
- 把
InfoLogger输出到os.Stdout,方便管道处理或重定向到文件 - 把
ErrorLogger和FatalLogger输出到os.Stderr,符合 Unix 习惯,也便于分离错误流 -
FatalLogger.Fatal()仍会调用os.Exit(1),不可恢复
Fatal 不是 “严重错误日志”,而是 “程序必须退出” 的信号
很多人误以为 log.Fatal 是用来记录“高危错误”的,其实它核心语义是“这个错误发生后,程序已无法安全继续运行”。比如:
- 监听端口失败且无备选方案
- 加载必要配置失败(如 JWT 密钥为空)
- 初始化全局数据库连接池失败
相反,以下情况不该用 Fatal:
- HTTP 请求处理中数据库查询失败(应返回 500 并记录 error 日志)
- 用户上传文件格式错误(应返回 400)
- 第三方 API 调用超时(应降级或重试)
滥用 Fatal 会导致服务频繁崩溃,尤其在微服务或容器环境中,可能触发反复重启循环。
真正需要分级时,直接换库比自己造轮子更稳妥
标准库 log 的设计哲学是“足够简单”,它不打算替代专业日志系统。一旦项目规模上升、需要如下能力,就该考虑迁移:
- 按级别动态控制输出(比如开发环境显示 debug,生产只显示 error)
- 结构化日志(JSON 输出,字段可被 ELK / Loki 解析)
- 日志采样、异步写入、滚动切片
- 上下文透传(
ctx中的 traceID 自动注入每条日志)
推荐起步选择:github.com/sirupsen/logrus(API 清晰,文档全)或 go.uber.org/zap(高性能,适合高吞吐场景)。它们都支持标准库风格的 log.WithField 或 logger.Info 调用,迁移成本低。
别花时间给 log 打补丁加 level 字段——Go 生态里,日志分级这件事,早有成熟解法,而且比你预想的更轻量。
# ai
# 自己的
# 这是
# 帮你
# 很多人
# 如果你
# 用了
# 不存在
# 这件事
# 第三方
# 不支持
# 配置文件
# 端口
# http
# js
# json
# go
# golang
# 循环
# Error
# 标准库
# 接口
# 数据库
# git
# github
# printf
# 异步
# 封装
# 切片
# elk
# 开发环境
# print
# unix
相关栏目:
<?muma
$count = M('archives')->where(['typeid'=>$field['id']])->count();
?>
【
AI推广<?muma echo $count; ?>
】
<?muma
$count = M('archives')->where(['typeid'=>$field['id']])->count();
?>
【
SEO优化<?muma echo $count; ?>
】
<?muma
$count = M('archives')->where(['typeid'=>$field['id']])->count();
?>
【
技术百科<?muma echo $count; ?>
】
<?muma
$count = M('archives')->where(['typeid'=>$field['id']])->count();
?>
【
谷歌推广<?muma echo $count; ?>
】
<?muma
$count = M('archives')->where(['typeid'=>$field['id']])->count();
?>
【
百度推广<?muma echo $count; ?>
】
<?muma
$count = M('archives')->where(['typeid'=>$field['id']])->count();
?>
【
网络营销<?muma echo $count; ?>
】
<?muma
$count = M('archives')->where(['typeid'=>$field['id']])->count();
?>
【
案例网站<?muma echo $count; ?>
】
<?muma
$count = M('archives')->where(['typeid'=>$field['id']])->count();
?>
【
精选文章<?muma echo $count; ?>
】
相关推荐
- c++23 std::expected怎么用 c+
- Win11讲述人怎么关闭_Win11误触开启语音朗
- Windows10怎样连接蓝牙设备_Windows
- Win11声音忽大忽小怎么办 Win11音频增强功
- Windows10如何更改鼠标灵敏度_Win10鼠
- Python对象比较与排序_魔术方法解析【教程】
- Win11怎么关闭粘滞键_彻底禁用Windows
- Win11怎么关闭自动调节亮度 Win11禁用内容
- PHP 中如何在函数内持久化修改引用变量的指向
- 如何在网页无标准表格标签时高效提取结构化数据
- 如何使用Golang table-driven基准
- 如何使用Golang实现跨域请求支持_Golang
- 如何使用Golang实现多重错误处理_Golang
- php8.4新语法match怎么用_php8.4m
- PowerShell怎么创建复杂的XML结构
- Win11怎么用设置清理回收站_Win11设置清理
- 如何在Golang中使用replace替换模块_指
- Win11怎么设置环境变量_Win11配置Path
- 如何使用Golang反射创建map对象_动态生成键
- Win11怎么设置任务栏对齐方式_Windows1
- Python日志系统设计与实现_高可观测性架构实战
- Python 模块的 __name__ 属性如何由
- Windows10如何更改桌面背景_Win10个性
- 如何在Golang中实现CI/CD流水线自动化测试
- Win11怎么检查TPM2.0模块_Windows
- Win11怎么设置右键刷新选项_Windows11
- Mac怎么进行语音输入_Mac听写功能设置与使用【
- Win10路由器怎么隐藏ssid Win10隐藏w
- Windows如何使用BitLocker To G
- 如何在 Python 测试中动态配置 @backo
- php增删改查报错1054怎么办_字段名错误排查修
- Python文件管理规范_工程实践说明【指导】
- Win11怎么清理C盘虚拟内存_Win11清理虚拟
- Windows 10怎么把任务栏放在屏幕上方_Wi
- PyTorch DDP 多进程训练在 Kaggle
- 如何使用Golang优化模块引入路径_Golang
- 零基础学会Python自动化办公_高效处理Exce
- mac怎么安装字体_MAC添加第三方字体与字体册管
- 如何在 Django 中修改用户密码后保持会话不丢
- Win11怎么设置默认邮件应用_Windows11
- Win10怎么卸载剪映_Win10彻底卸载剪映方法
- 如何使用Golang配置安全开发环境_防止敏感信息
- 手机php文件怎么变成mp4_安卓苹果打开php转
- 如何在Golang中处理模块包路径变化_Golan
- c# Task.Yield 的作用是什么 它和Ta
- PHP的Workerman对架构扩展有啥帮助_应用
- Win11怎么查看显卡显存_查询Win11显卡详细
- 如何使用正则表达式批量替换重复的 *- 模式为固定
- Win10怎么关闭自动更新错误弹窗_Win10策略
- 如何使用Golang安装依赖库_管理模块和第三方包

QQ客服