Java日志规范_日志中不能拼接字符串-程序员宅基地

技术标签: java  

日志文件:

Logger.debug():yyyy-mm-dd-debug.i.log  按天和200M滚动,打印调试信息,保留5天

Logger.info():  yyyy-mm-dd-info.i.log    按天和200M滚动,打印业务日志,保留15天

Logger.error(): yyyy-mm-dd-error.i.log  按天和200M滚动, 打印错误信息,保留30天

日志格式:

yyyy-MM-dd HH:mm:ss.SSS 级别 IP 进程号 ---线程 类路径 - 消息内容

增加IP和进程号,便于确认具体实例

1.考虑日志对性能的影响:日志的频繁打印会对模块的性能产生极大的影响。当日志产生的速度大于日志文件写磁盘的速度,会导致日志内容积压在内存中,导致内存泄漏。

2.可对系统接口配置切面日志内容,避免打印重复内容,打印级别debug级别

3.在一个对象中通常只使用一个Logger对象,Logger应该是static final的,只有在少数需要在构造函数中传递logger的情况下才使用private final。

4.输出Exceptions的全部Throwable信息,因为logger.error(msg)和logger.error(msg,e.getMessage())这样的日志输出方法会丢失掉最重要的StackTrace信息。

5.不允许出现System print(包括System.out.println和System.error.println)语句。

6.不允许出现printStackTrace。

7.日志性能的考虑,如果代码为核心代码,执行频率非常高,慎用,不得不打印时最好使用

占位符可以减少参数构造的开销

8.只打印有意义的日志

通常情况下在程序日志里记录一些比较有意义的状态数据:程序启动,退出的时间点;程序运行消耗时间;耗时程序的执行进度;重要变量的状态变化。

9.在日志相关数据输出的时要特别注意对敏感信息的保护,比如身份证号、密码、余额等,不能将之输出到日志中,可做脱敏处理。

10.Log的内容一定要确保不会因为Log语句的问题而抛出异常造成中断,注意空指针等情况

反例:

//request对象如果是null,那么就会出现NPE。

log.debug("Processing request with id: {}", request.getId());

11.使用参数化信息的方式:禁止字符串拼接

LOGGER.debug("当前用户是:" + user + ",传入参数是:" + userId);

严禁使用字符串拼接的方式打印日志,可读性、可维护性都比较差。

建议的写法如下:

LOGGER.debug("当前用户是:{},传入参数是:{},返回值是:{},用户信息:{}", a,b new Object[]{token, userId, userInfo, authcInfo});

12.禁止直接在for循环中打印日志,特别是for循环特别大时

13.不打印无用、无意义、不完全的日志,建议使用主语+谓语+宾语+状语的格式

例如:log.warn("Unknown message type");

log.info("调用客户系统开始...");

log.info("调用客户系统结束...");

14.日志打印的时候,假如需要处理列表、数组类的数据,最好是只输出对象的大小,或者某些关键字段,例如:编号,如果将全部内容打印出来可能会占用大量的资源

15..需要明确对象的toString方法是否输出的东西就是你想要的东西,是否需要重写对象的toString方法

建议打印对象信息时,可以采用json格式打印,这样查看起来更清晰。

log.info("用户绑卡,实名校验,用户信息:{}", JSONObject.toJSONString(userInfo));

版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://blog.csdn.net/weixin_40453395/article/details/120493318

智能推荐

Linux系统编程@终端IO-程序员宅基地

文章浏览阅读121次。Linux系统中终端设备种类终端是一种字符型设备,有多种类型,通常使用tty来简称各种类型的终端设备。终端特殊设备文件一般有以下几种: 串行端口终端(/dev/ttySn) ,伪终端(/dev/pty/),控制终端(/dev/tty) ,控制台终端(/dev/ttyn, /dev/console)。1.串行端口终端(Serial Port Terminal)是使用计算机串行..._unsigned charx_char;/* xon/xoff char */

在安卓手机上面使用window.location.href失效的问题_安卓手机无法在吃触发 window.location.href-程序员宅基地

文章浏览阅读5.1k次。问题:在低版本的安卓手机中使用window.location.href跳转失效解决思路1:分析:在跳转链接后面添加时间戳,因为考虑到是低版本可能存在缓存的问题所以采用在跳转链接后面添加动态的参数时间戳来刷新缓存的数据// 在跳转链接后面添加时间戳,因为考虑到是低版本可能存在缓存的问题所以采用在跳转链接后面添加动态的参数时间戳来刷新缓存的数据window.location.href = url+'?time='+((new Date()).getTime());解决思路2:分析: 在采用上面的方_安卓手机无法在吃触发 window.location.href

来一篇最全的自动化运维部署文档-程序员宅基地

文章浏览阅读1.3k次。本次搭建环境 svn + Jenkins + Docker + git + Rancher + Maven服务器配置,根据个人爱好分配服务器,只需要拓扑图中相邻的两个服务器保证通信即可,也可以放在一台服务器中上拓扑图跟着我的思路来一遍:  1、开发写代码,上传到svn服务器上,相信这个很容易理解。  2、使用Jenkins 拉取svn 代码,并结合maven插件转换成jar ..._项目部署运维文档怎么写

Dev-GridControl(二)控件属性_dev中怎么获设置某列的optionsbehavior.editable=troue-程序员宅基地

文章浏览阅读671次。1. GridControl修改表格为不可编辑状态 gridcontrol -->gridview -->OptionsBehavior -->Editable=false 即可;如果需要某一列是可编辑的。需要Editable=true下操作,操作事件是gridview中的ShowingEditor事件。private void gridView1_ShowingEditor(o..._dev中怎么获设置某列的optionsbehavior.editable=troue

LabVIEW 创建顺序的二维数组_labview生成二维数组-程序员宅基地

文章浏览阅读1.2k次,点赞2次,收藏2次。顺序的二维数组_labview生成二维数组

如何成为优秀的技术主管?你要做到这三点 -程序员宅基地

文章浏览阅读139次。阿里妹导读:技术主管,又叫「技术经理」,英文一般是 Tech Leader ,简称 TL。随着工作经验的不断积累,能力的不断提升,每个人都有机会成为Team Leader。然而在机会到来前,我们必须提前做好准备,对TL的工作职责有一定了解。当然,这也会为当下更好地配合TL工作打下基础。今天,阿里巴巴高级技术专家云狄将结合自己多年的经验,从开发规范、..._随着数据量的增大系统性能会不会出现明显问题?

随便推点

php datatable ajax,JQuery DataTable删除行后的页面更新利用Ajax解决-程序员宅基地

文章浏览阅读75次。使用Jquery的DataTable进行数据表处理非常方便,常遇到的一个问题就是删除一行后页面必须进行更新,需要注意的方法如下:前台页面中初始化table时注意:var table = $('#sorting-advanced');table.dataTable({'bServerSide': true,'sAjaxSource': 'servlet/UserList','bProcessing'..._fnpagechange(1, true)

Spring Boot:实现与数据库的连接_springboot连接数据库-程序员宅基地

文章浏览阅读1.1w次,点赞8次,收藏70次。快速开发:Spring Boot提供了一系列的开箱即用的功能和特性,使得开发人员可以快速构建和部署应用程序。简化配置:Spring Boot自动配置了许多常见的配置,如数据源、Web服务器、安全等等,这样开发人员可以专注于业务逻辑的实现,而不是配置。易于部署:Spring Boot可以将应用程序打包成可执行的JAR或WAR文件,这样可以方便地部署到任何支持Java的平台上。易于测试:Spring Boot提供了一系列的测试工具和框架,可以方便地进行单元测试、集成测试和端到端测试。_springboot连接数据库

Python Flask交互基础(GET、 POST 、PUT、 DELETE)_python flask post-程序员宅基地

文章浏览阅读9.3k次,点赞11次,收藏50次。目录前言第一个flask程序GET类接口POST类接口PUT类接口前言看到这篇文章我就默认你已经在你的电脑上使用 pipenv搭建好了虚拟环境并且设置好了开发环境(pycharm)。如果没有,请参照这篇文章。文章传送门第一个flask程序from flask import Flask #导入Flask类app = Flask(__name__) # 实例化[email protected]('/') # 使用路由,给 hello 函数定义一个路由,然后游览器通过http 请求得到相对应的数_python flask post

Oracle使用sql技巧-程序员宅基地

文章浏览阅读186次。自增主键是MySQL中的一个特性。在Oracle中需要创建序列CREATESEQUENCEs_userId--s_userId自动增长列INCREMENTBY1--每次加几个STARTWITH1--从1开始计数NOMAXVALUE--不设置最大值NOCYCLE--一直累加,不循环NOCACHE--..._oraclesql使用技巧

*** stack smashing detected ***: <unknown> terminated 已放弃 (核心已转储) 栈溢出-程序员宅基地

文章浏览阅读5.2k次,点赞3次,收藏6次。对文件 gdb test core 出现如下问题Program terminated with signal SIGABRT, Aborted.#0 __GI_raise (sig=sig@entry=6) at ../sysdeps/unix/sysv/linux/raise.c:5151 ../sysdeps/unix/sysv/linux/raise.c: 没有那个文件或目..._*** stack smashing detected ***: terminated

仅输入单张图片,就能“看”出物体材质!这篇图形学论文已被SIGGRAPH 2021收录...-程序员宅基地

文章浏览阅读1.2k次。OPPO日前,计算机图形学顶级国际学术会议ACM SIGGRAPH 2021收录了Highlight-aware Two-stream Network for Single-image ..._图片分析 判断材质

推荐文章

热门文章

相关标签