Perf4J@Profiled的几种写法[通俗易懂]

2022-08-11 20:51:25 浏览数 (1)

大家好,又见面了,我是你们的朋友全栈君。

在项目中使用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

0 人点赞