本文共 1109 字,大约阅读时间需要 3 分钟。
一下三条tips是根据项目提炼了的经验总结。主要提供一种BugFree的思路
1.写日志时要养成的好习惯log.warn(String.format("[接口名或操作名][Key Msg]:%s happens.because[param],[solve clue]",errorObj));
以上两点的代码举例:
@Transactional(value = "transactionManager", rollbackFor=Exception.class) public Boolean addLog(Request request) throws Exception { Boolean result = false; if(null!=request){ ResultLogDOResult =Manager.getLogById(request.getId()); logger.info("add request num is"+ request.getId()); } //要指出正确或异常的数据ID,方便定位 else{ logger.error("查询addLog接口信息失败,[Id=" + Id + "]"); throw new Exception("不存在数据,ID:"+request.getId()); } return result; }
2.定位错误日志时,主要用时间和内容关键字来定位错误信息,而requestId不具有描述性
在log的配置文件里添加相关业务的log文件名,便于统一管理。 从上图可知,当预约业务有问题则可以去xshell中找appointreg.log,具体方式如下图: 整个背景流程大概是这样:Arthas 是Alibaba开源的Java诊断工具。支持Linux/Mac/Windows,采用命令行交互模式。
它可以在线排查问题,无需重启;动态跟踪Java代码;实时监控JVM状态。 下面是资源和教程: 关于具体使用的源码和步骤请见我的另一篇博客:转载地址:http://nfrsi.baihongyu.com/