使用Perf4J进行性能分析和监控.docVIP

  1. 1、本文档共9页,可阅读全部内容。
  2. 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  5. 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  6. 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  7. 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  8. 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
使用Perf4J进行性能分析和监控.doc

使用Perf4J进行性能分析和监控 由安博测试空间技术中心/提供 。 Web 2.0风格应用的服务器端的常见场景: Web请求,分发给负责产生响应的组件。 LDAP服务器进行安全验证。 。 Web服务。 。 。 AJAX代码产生其他的请求,与服务器端交互。 “为何我的网页反应迟钝?”这样问题的回答需要研究多个组件和执行路径,同时需要生产环境中所有应用组件的详细性能数据。 Perf4JJava服务器端计时代码、记录日志和监控结果。对于熟悉诸如log4j日志框架的开发人员来说,可以这样类比: Perf4J is to System.currentTimeMillis() as log4j is to System.out.println() Perf4J呢?回想一下过去还没有广泛应用Java日志记录框架的糟糕岁月,我们大多数人如何添加日志记录语句。我们使用System.out.println()作 为一种“简陋的调试器”,利用这种快捷但糟糕的方式记录信息。我们很快意识到,这是不够的。我们希望把记录语句输出到专门的日志文件中(如果可能的话,多 个不同文件),也许可以每天覆盖日志。我们需要能够设定重要性的不同级别以输出不用的日志语句,可以选择在不改变代码的情况下在特定环境下只输出特定日 志,或者在不同环境中改变日志格式。因此,log4j提供的丰富功能来源于原始想法,是一种“更好的 ”System.out.println()日志语句。 Java新手发现他们需要添加性能监控代码时,他们经常这样做: long start = System.currentTimeMillis(); // execute the block of code to be timed (ms for block n was: + (System.currentTimeMillis() - start)); JMX输出性能指标以便于启动监控器在性能下降的情况下发出警报。此外,他们还希望计时语句可以和类似 log4j的框架配合使用。 Perf4JPer4J是由H开发的,其基础设施的分布式特性和网站的高可用性及性能需求需要深入的性能分析。Perf4J的特点包括: stop watch计时机制。 。 log4j appender,可以在运行时应用中生成数据和图表,计划在以后的版本中支持java.util.logging和logback。 JMX属性的形式发布性能数据,在数据超过指定阈值时发送通知。 @Profiled注解和一套自定义机制,允许在与AOP框架(如AspectJ或者Spring AOP)集成时巧妙的计时。 Perf4J开发人员指南来了解集成Perf4J的详细信息。 StopWatch类开发计时代码 org.perf4j.LoggingStopWatch: StopWatch stopWatch = new LoggingStopWatch(); //... execute code here to be timed stopWatch.stop(example1, custom message text); stop()方法的调用记录了执行时间并打印日志信息。默认情况下,基类LoggingStopWatch将输出打印到System.err流中。但是大多数情况下,你需要使用一个集成到现有Java日志框架(如Log4JStopWatch、CommonsLogStopWatch或者Slf4JStopWatch)的子类。下面是一些stop watch的输出示例: start[1233364397765] time[499] tag[example1] message[custom message text] start[1233364398264] time[556] tag[example1] message[custom message text] start[1233364398820] time[698] tag[example1] message[custom message text] LogParser创建统计数据和图表 stop watch输出相比直接调用System.currentTimeMillis()来说没有很大的改进,但真正的好处在于能够解析这些输出以生成统计数据和图表。LogParser通过tag和时间片把stop watch输出分组,生成详细的统计信息和可选的时间序列图(使用Google Chart API)。下面是一些使用默认文本格式(也支持csv格式)的示例输出: Performance Statistics 20:32:00 - 20:32:30 Tag

文档评论(0)

docindoc + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档