异常打Error日志,Review的时候被喷了

2025-02-11T00:00:00Z | 2分钟阅读 | 更新于 2025-02-11T00:00:00Z

@
异常打Error日志,Review的时候被喷了

前几天在提交一个MR的Code Review时,遇到了一个关于日志级别的有趣讨论。我的原始代码是一个获取标签列表的方法,实现如下:

public async Task<TagInfo[]> GetTagListAsync()
{
    try
    {
        return await _apiClient.GetTagListAsync();
    }
    catch (Exception ex)
    {
        Logging.Error(ex.Message, ex);
    }
}

Reviewer提了一个令我没想到的问题:“为什么要在这里使用Error级别的日志?”

问题探讨

我最初的反应是:“捕获了异常,难道不应该用Error级别吗?“我们就日志级别适用场景 「讨论」了约5分钟。

Reviewer的观点:

  1. 谁会去看这个日志?
  2. 这个接口异常是否会阻塞主流程继续执行?
  3. 如果真的出现了异常,我们如何主动监控这类异常?

他随后分享了一个Stack Overflow上关于日志级别的讨论:When to use the different log levels

解决方案

经过讨论,我被说服了,在这种情况下使用Warning级别更为合适。修改后的代码如下:

public async Task<TagInfo[]> GetTagListAsync()
{
    try
    {
        return await _apiClient.GetTagListAsync();
    }
    catch (Exception ex)
    {
        // remoteLog参数会将日志上传到ELK,便于后续通过关键字进行分析
        Logging.Warn($"Failed to get tag list, msg:{ex.Message}", ex, remoteLog: true);
    }
}

日志级别的最佳实践

Stack Overflow上的高票回答提供了一个清晰的日志级别使用指南图表,非常值得参考。

  • Error:用于确实影响程序正常执行的严重错误
  • Warning:适用于非关键路径上的异常或可恢复的错误
  • Info:记录程序正常运行的重要信息
  • Debug:开发调试期间的详细信息
  • Trace:最详细的日志信息,通常用于问题诊断

在这个案例中,获取标签列表失败不会影响核心业务流程,因此使用Warning级别更为恰当。这种区分有助于运维人员快速定位真正严重的问题,避免在大量Error日志中遗漏关键错误。

下面这个图是高赞回答的博主贴的,很清晰的说明了何时使用什么级别的日志。

image.png The remaining content of your post.

© 2026 火箭的博客

🌱 Powered by Hugo with theme Dream.

爱好
  • 三国演义:从大二开始听评书版的《三国演义》,现在主要是作为睡前小故事来听(我估计是第七八遍了)
  • 写代码:没错,写代码也是我的爱好。只要出门超过半天,我基本都会背着笔记本,随时可能进入“编码模式”。
  • 健身:曾经的爱好。结婚之后就逐渐被抛弃了 🤷,结婚一年涨了10斤。
  • 看电影:后续可能会写影评。
  • 探索新事物和工具:准备开一个主题,专门分享我接触到的各种新玩意儿。
关于我

👋 你好,我是 huojian (火箭)

欢迎来到我的个人博客!建立这个小站的初衷,是想在浩瀚的互联网中拥有一块属于自己的“数字花园”。我经常从各类优秀的博客中汲取养分,现在,我也想成为那个输出和分享的人。

这里没有刻板的文章更新 KPI,更多的是我个人的技术沉淀、学习笔记以及生活碎片的真实记录。

👨‍💻 关于我与我的技术栈

我是一名客户端软件工程师,日常与代码和系统架构打交道。在技术探索的道路上,我享受解决复杂问题带来的成就感,也喜欢折腾各种能提升幸福感的工具。

在这里,你可能会看到我分享以下内容:

  • 💻 开发与架构探讨: 探讨 WPF/C# 领域的开发经验、代码质量优化,以及诸如客户端热修复 (Hotfix) 系统设计等我在实际项目中遇到并解决的挑战。
  • 🛠️ 工作流与跨平台折腾: 记录我游走在 Windows 与 macOS 环境下的效率心得。从外设配置到好用的跨平台开发工具,分享如何打造顺手的生产力环境。
  • 🐳 自托管与数字生活: 我是个“自建服务”爱好者。会不定期掉落关于 Docker 部署、云服务器折腾指南,以及如何搭建属于自己的 RSS 阅读环境等教程。
  • 📝 学习笔记与自我精进: 记录各种技术学习心得。同时,我也在持续死磕英语,努力提升口语和写作能力,告别“哑巴英语”,相关的学习路径和思考也会记录在这里。

💡 我的理念

“Talent is enduring patience.” (才能即是长久的忍耐)

我相信持续输出的力量。无论是深度的技术解析,还是一个简单的开发踩坑记录,亦或是一篇普通的生活随笔,都是打造个人 IP 与技术影响力的基石。

📬 建立连接

非常高兴能在这里与同样喜欢写代码、喜欢阅读的你相遇。如果你对我的文章有共鸣,或者想交流技术与生活,欢迎随时找我:

  • GitHub: @huojian-jan
  • RSS 订阅: 欢迎通过博客右上角的 RSS 订阅我的最新文章。
记录什么?
  • 学习笔记

  • 一些想法:记录日常思考,不一定有结论,更像是一种随手的表达。

  • 旅游与随笔:旅行时的见闻与感受,以及偶尔的文字随笔。