码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • Java日志系列——规范化日志


    Java日志系列——规范化日志

    • 规范化日志
      • 原则1:使用参数化信息打印
      • 原则2:若带有参数变量必须使用`[]`隔离
      • 原则3:严格遵守Level
        • Error
        • Warn
        • Info
        • Debug
        • Trace
      • 原则4:文件输出

    规范化日志

    原则1:使用参数化信息打印

    当我们打印日志时我们一定要使用参数化信息的方式进行打印而不要使用字符串拼接的方式,以避免内存占用

    logger.warn("....{}..{}..",arg1,arg2);
    logger.warn("....{}..{}..",args[] argList);
    
    • 1
    • 2

    原则2:若带有参数变量必须使用[]隔离

    这样更加有利于问题排查

    logger.warn("....[{}]..[{}]..",arg1,arg2);
    
    • 1

    原则3:严格遵守Level

    Error

    影响到程序正常运行、当前请求正常运行的异常情况

    1. 打开配置文件失败
    2. 所有第三方对接的异常(包括第三方返回错误码)
    3. 所有影响功能使用的异常,包括:SQLException和除了业务异常之外的
    4. 所有异常(RuntimeException和Exception)
    5. 不应该出现的情况,比如要使用阿里云传图片,但是未响应
    6. 如果有Throwable信息,需要记录完成的堆栈信息:

    Warn

    不应该出现但是不影响程序、当前请求正常运行的异常情况:

    1. 有容错机制的时候出现的错误情况
    2. 找不到配置文件,但是系统能自动创建配置文件
    3. 即将接近临界值的时候,例如:缓存池占用达到警告线,业务异常的记录,比如:用户锁定异常

    Info

    系统运行信息

    1. Service方法中对于系统/业务状态的变更
    2. 主要逻辑中的分步骤: 1.初始化什么 2.加载什么
    3. 外部接口部分
    4. 客户端请求参数(REST/WS)
    5. 调用第三方时的调用参数和调用结果
    6. 对于复杂的业务逻辑,需要进行日志打点,以及埋点记录,比如电商系统中的下订单逻辑,以及OrderAction操作(业务状态变更)
    7. 调用其他第三方服务时,所有的出参和入参是必须要记录的(因为你很难追溯第三方模块发生的问题)

    Debug

    可以填写所有的想知道的相关信息(但不代表可以随便写,debug信息要有意义,最好有相关参数)

    1. 生产环境需要关闭DEBUG信息
    2. 如果在生产情况下需要开启DEBUG,需要使用开关进行管理,不能一直开启。

    Trace

    特别详细的系统运行完成信息,业务代码中,不要使用.(除非有特殊用意,否则请使用DEBUG级别替代)

    原则4:文件输出

    1. 日志的文件输出最好指定到项目下的logs目录下统一管理
    2. 文件尽量使用量和时间处理(严格遵守时间格式化)
    3. 过期日志尽量保存15日
    4. 过期日志若不使用进行压缩处理
  • 相关阅读:
    leetcode 654 最大二叉树
    Swagger
    Hive ,Hsql行转列、列转行实现
    现代企业管理笔记——领导
    DNS域名解析
    数据结构(C语言版)严蔚敏--->一些操作相关数据结构的题目
    C语言中的文件操作指南
    C/C++:双重循环中的break
    低代码可以成为一股公益力量,Mendix 公司“Low-Code for Good”全球黑客马拉松即将拉开帷幕
    一文看懂推荐系统:召回04:离散特征处理,one-hot编码和embedding特征嵌入
  • 原文地址:https://blog.csdn.net/qq_51553982/article/details/126668136
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号