六狼论坛

 找回密码
 立即注册

QQ登录

只需一步,快速开始

新浪微博账号登陆

只需一步,快速开始

搜索
查看: 133|回复: 0

Perf4J@Profiled的几种写法

[复制链接]

升级  78.67%

48

主题

48

主题

48

主题

秀才

Rank: 2

积分
168
 楼主| 发表于 2013-2-7 20:55:07 | 显示全部楼层 |阅读模式
在项目中使用Perf4J的最简便的方法就是直接在任何一个需要监控的方法上加上@Profiled 注释即可。
 
@Profiled 支持一些定制,在此记录几种@Profiled 写法:
 
1、最简写法
@Profiled  
 

   由此产生的日志语句形如: 
2009-09-07 14:37:23,734 [main] INFO org.perf4j.TimingLogger - start[开始时间] time[执行耗时] tag[方法名]  
2、带logger标识
@Profiled(logger = "test.PriceService")    由此产生的日志语句形如:
2009-09-07 14:37:23,734 [main] INFO test.PriceService - start[开始时间] time[执行耗时] tag[方法名]     简要说明:
   不加该标识,则所有的日志类名均为 org.perf4j.TimingLogger ,当2个类中的方法重名时,无法区分是哪个方法。
 
3、带tag标识
 
@Profiled(tag = "search({$0},{$1},{$2})")    由此产生的日志语句形如: 
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标识 
 
@Profiled(massage= "测试")    由此产生的日志语句形如: 
2009-09-07 14:37:23,734 [main] INFO org.perf4j.TimingLogger - start[开始时间] time[执行耗时] tag[方法名] message[测试]    简要说明:
   message的作用即可以在输出的内容后加上任何自定义的内容。
 
 5、带logFailuresSeparately标识 
@Profiled(logFailuresSeparately= true)    由此产生的日志语句形如:
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
您需要登录后才可以回帖 登录 | 立即注册 新浪微博账号登陆

本版积分规则

快速回复 返回顶部 返回列表