大家好,又见面了,我是你们的朋友全栈君。
在项目中使用Perf4J的最简便的方法就是直接在任何一个需要监控的方法上加上@Profiled 注释即可。
@Profiled 支持一些定制,在此记录几种@Profiled 写法:
1、最简写法
代码语言:javascript复制@Profiled
由此产生的日志语句形如:
代码语言:javascript复制2009-09-07 14:37:23,734 [main] INFO org.perf4j.TimingLogger - start[开始时间] time[执行耗时] tag[方法名]
2、带logger标识
代码语言:javascript复制@Profiled(logger = "test.PriceService")
由此产生的日志语句形如:
代码语言:javascript复制2009-09-07 14:37:23,734 [main] INFO test.PriceService - start[开始时间] time[执行耗时] tag[方法名]
简要说明:
不加该标识,则所有的日志类名均为 org.perf4j.TimingLogger ,当2个类中的方法重名时,无法区分是哪个方法。
3、带tag标识
代码语言:javascript复制@Profiled(tag = "search({$0},{$1},{$2})")
由此产生的日志语句形如:
代码语言:javascript复制2009-09-07 14:37:23,734 [main] INFO org.perf4j.TimingLogger - start[开始时间] time[执行耗时] tag[search(a,b,c)]
简要说明:
当方法有参数时,可以通过{x}输出参数值,当参数为一个对象时,可以通过{x.属性}的方式法输出对象的属性值;
tag标识支持JEXL表达式。
4、带message标识
代码语言:javascript复制@Profiled(massage= "测试")
由此产生的日志语句形如:
代码语言:javascript复制2009-09-07 14:37:23,734 [main] INFO org.perf4j.TimingLogger - start[开始时间] time[执行耗时] tag[方法名] message[测试]
简要说明:
message的作用即可以在输出的内容后加上任何自定义的内容。
5、带logFailuresSeparately标识
代码语言:javascript复制@Profiled(logFailuresSeparately= true)
由此产生的日志语句形如:
代码语言:javascript复制2009-09-07 14:37:23,734 [main] INFO org.perf4j.TimingLogger - start[开始时间] time[执行耗时] tag[方法名.failure]
简要说明:
加上此标识,会输出方法执行结果,成功时为方法名.success ,当方法执行中出现异常时为方法名.failure。
附:官网对此项的说明地址:http://perf4j.codehaus.org/devguide.html#Using_Spring_AOP_to_Integrate_Timing_Aspects
发布者:全栈程序员栈长,转载请注明出处:https://javaforall.cn/131362.html原文链接:https://javaforall.cn