如何使用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; ?>
】
相关推荐
- Win11怎么更改盘符_Win11磁盘管理修改驱动
- 如何使用Golang指针与接口结合_实现方法调用和
- TestNG的testng.xml配置文件怎么写
- Win11任务栏怎么固定应用 Win11将软件图标
- Linux如何安装Golang环境_Linux下G
- c++ nullptr与NULL区别_c++11空
- php订单日志怎么记录物流_php记录订单物流变更
- PHP cURL GET请求:正确设置认证与自定义
- Python深度学习实战教程_神经网络模型构建与训
- 为什么本地php环境运行php脚本卡顿_php执行
- php删除数据怎么清空表_truncate与del
- php打包exe怎么传递参数_命令行参数接收方法【
- Python音视频处理高级项目教程_FFmpegP
- Python生成器表达式内存优化_惰性计算说明【指
- c++怎么编写动态链接库dll_c++ __dec
- Win11怎么查看显卡显存_查询Win11显卡详细
- 获取 PHP 文件最后修改时间的正确方法
- Windows如何使用BitLocker To G
- Win11怎么更改管理员名字 Win11修改账户名
- XML的“混合内容”是什么 怎么用DTD或XSD定
- Win11怎么设置按流量计费_Win11限制后台流
- 如何在 Go 中创建包含 map 的 slice(
- PythonWeb前后端整合项目教程_FastAP
- Mac的Time Machine怎么用_Mac系统
- php嵌入式多设备通信怎么实现_php同时管理多个
- 为什么Go建议使用error接口作为错误返回_Go
- Win10如何卸载Skype_Win10卸载Sky
- 如何在Golang中使用log包输出不同级别日志_
- 如何用正则与预处理高效拦截带干扰符的恶意域名
- php485返回空数组怎么回事_php485数据接
- 如何在 Go 中调用动态链接库(.so)中的函数
- Win10电脑怎么设置IP地址_Windows10
- Mac怎么安装软件_Mac安装dmg与pkg文件的
- Windows7怎么找回经典开始菜单_Window
- Python对象比较与排序_集合使用说明【指导】
- Win11怎么设置单手模式_Win11触控键盘布局
- 如何使用Golang实现容器安全扫描_Golang
- Win11怎么设置任务栏大小_Windows11注
- 如何用正则表达式精确匹配“start”到“end”
- Go 中 defer 在 goroutine 内部
- Win11怎么设置声音输出设备_Windows11
- Windows10蓝屏代码DPC_WATCHDOG
- Python与MongoDB NoSQL开发实战_
- Win11鼠标灵敏度怎么调 Win11鼠标指针移动
- 如何在JavaScript中动态拼接PHP的bas
- PowerShell怎么创建复杂的XML结构
- Win10怎样设置闹钟贪睡时间 Win10闹钟贪睡
- Win10闹钟铃声怎么自定义 Win10闹钟自定义
- How to Properly Use NumPy
- Win10怎么关闭自动更新错误弹窗_Win10策略

QQ客服