仓酷云

标题: JAVA网站制作之利用Perf4J举行功能剖析和监控仓酷云 [打印本页]

作者: 仓酷云    时间: 2015-1-18 11:32
标题: JAVA网站制作之利用Perf4J举行功能剖析和监控仓酷云
C#是不行的,比如说美国的航天飞船里就有java开发的程序以上是我的愚见,其实不管那种语言,你学好了,都能找到好的工作,很多开辟职员都很熟习墨菲法例的一个例子:他们发明在消费了大批工夫确保使用程序在开辟情况中疾速和天真以后,在公布到临盆情况的时分功能会难以想象的年夜幅下落。更糟的是,使用程序平常运转一般,老板大概主要客户操纵使用的时分却反响迟缓。具体的日记纪录和剖析关于追踪这些间歇性的功能瓶颈尤其主要.
但是,现今天下充斥了面向服务的架构和散布式的使用,查找功能瓶颈对应的组件极为坚苦。思索一个典范Web2.0作风使用的服务器真个罕见场景:
关于“为什么我的网页反响愚钝?”如许成绩的回覆必要研讨多个组件和实行路径,同时必要临盆情况中一切使用组件的具体功能数据。
Perf4J是一款开源工具包,用于增加Java服务器端计时期码、纪录日记和监控了局。关于熟习诸如log4j日记框架的开辟职员来讲,能够如许类比:
Perf4JistoSystem.currentTimeMillis()aslog4jistoSystem.out.println()

怎样使用这个类比了解Perf4J呢?回忆一下已往还没有普遍使用Java日记纪录框架的糟光阴,我们年夜多半人怎样增加日记纪录语句。我们利用System.out.println()作为一种“大略的调试器”,使用这类快速但糟的体例纪录信息。我们很如意识到,这是不敷的。我们但愿把纪录语句输入到专门的日记文件中(假如大概的话,多个分歧文件),大概能够天天掩盖日记。我们必要可以设定主要性的分歧级别以输入不必的日记语句,能够选择在不改动代码的情形下在特定情况下只输入特定日记,大概在分歧情况中改动日记格局。因而,log4j供应的丰厚功效来历于原始设法,是一种“更好的”System.out.println()日记语句。
相似的,当Java老手发明他们必要增加功能监控代码时,他们常常如许做:
  1. longstart=System.currentTimeMillis();//executetheblockofcodetobetimedlog.info("msforblocknwas:"+(System.currentTimeMillis()-start));
复制代码
可是很快,这些开辟职员发明他们必要更多的信息,综合的功能统计数据如均匀、最小、最年夜、尺度差和特准时间段内每秒的事件处置量。他们但愿将这些数据绘成及时图表监控运转服务器上的成绩,大概经由过程JMX输入功能目标以便于启动监控器在功能下落的情形下收回警报。别的,他们还但愿计时语句能够和相似log4j的框架共同利用。
Perf4J的方针是经由过程易于集成(和扩大)的开源软件包供应这些功效。Per4J是由Homeaway.com开辟的,其基本举措措施的散布式特征和网站的高可用性及功能需求必要深切的功能剖析。Perf4J的特性包含:

上面的例子展示了怎样轻松使用这些功效。能够经由过程Perf4J开辟职员指南来懂得集成Perf4J的具体信息。
使用StopWatch类开辟计时期码

org.perf4j.LoggingStopWatch类用于在代码中增加计时语句并打印到尺度输入大概日记文件中:
  1. StopWatchstopWatch=newLoggingStopWatch();//...executecodeheretobetimedstopWatch.stop("example1","custommessagetext");       
复制代码
stop()办法的挪用纪录了实行工夫并打印日记信息。默许情形下,基类LoggingStopWatch将输入打印到System.err流中。可是年夜多半情形下,你必要利用一个集成到现有Java日记框架(如Log4JStopWatchCommonsLogStopWatch大概Slf4JStopWatch)的子类。上面是一些stopwatch的输入示例:
  1. start[1233364397765]time[499]tag[example1]message[custommessagetext]start[1233364398264]time[556]tag[example1]message[custommessagetext]start[1233364398820]time[698]tag[example1]message[custommessagetext]
复制代码
利用LogParser创立统计数据和图表

固然默许的stopwatch输入比拟间接挪用System.currentTimeMillis()来讲没有很年夜的改善,但真实的优点在于可以剖析这些输入以天生统计数据和图表。LogParser经由过程tag和工夫片把stopwatch输入分组,天生具体的统计信息和可选的工夫序列图(利用GoogleChartAPI)。上面是一些利用默许文本格局(也撑持csv格局)的示例输入:
  1. PerformanceStatistics20:32:00-20:32:30TagAvg(ms)MinMaxStdDevCountcodeBlock1249.42487151.337codeBlock2.failure782.9612975130.817codeBlock2.success260.76500159.520PerformanceStatistics20:32:30-20:33:00TagAvg(ms)MinMaxStdDevCountcodeBlock1244.07494150.641codeBlock2.failure747.9531943125.321codeBlock2.success224.126398106.821PerformanceStatistics20:33:00-20:33:30TagAvg(ms)MinMaxStdDevCountcodeBlock1289.310464141.122codeBlock2.failure781.1599947135.18codeBlock2.success316.2115490112.613
复制代码
均匀实行工夫和每秒事件处置量的图表以指向GoogleChartServer的URL的情势天生。
JAVA网站制作之利用Perf4J举行功能剖析和监控仓酷云
登录/注册后可看大图

<br>
同时,固然LogParser默许从尺度输出中读取数据,可是你也能够指定一个来自运转时服务器的日记文件,用LogParser及时输入:
  1. tail-fperformance.log|java-jarperf4j-0.9.8.1.jar       
复制代码
集成Log4J

Perf4J的扩大功效年夜部分经由过程一套定制的log4jappender供应。如许开辟职员就可以在部署阶段经由过程十分熟习的日记框架来零零星散的增加剖析和监控功效(将来的Perf4J将供应定制logbackappender和java.util.logging处置器)。个中一个主要的功效是同意Perf4J作为JMXMBeans的属性展现功能数据,同时在功能低于可承受的阈值时发送JMX关照。由于JMX已成为处置和监控Java使用的尺度接口,供应Perf4JMBean开启了普遍的由第三方监控使用供应的功效。举例来讲,我们Homeaway的IT部门尺度化了Nagios和Cacti用于体系监控,这两个工具都撑持把MBeans作为数据源查询。
上面的log4j.xml文件示例显现了怎样启用用于JMX的Perf4Jappender:
  1. <?xmlversion="1.0"encoding="UTF-8"?><!DOCTYPElog4j:configurationSYSTEM"log4j.dtd"><log4j:configurationdebug="false"xmlns:log4j="http://jakarta.apache.org/log4j/"><!--Perf4Jappenders--><!--ThisAsyncCoalescingStatisticsAppendergroupsStopWatchlogmessagesintoGroupedTimingStatisticsmessageswhichitsendsonthefileappenderandperf4jJmxAppenderdefinedbelow--><appendername="CoalescingStatistics"class="org.perf4j.log4j.AsyncCoalescingStatisticsAppender"><!--TheTimeSliceoptionmeanstiminglogsareaggregatedevery10secs.--><paramname="TimeSlice"value="10000"/><appender-refref="fileAppender"/><appender-refref="perf4jJmxAppender"/></appender><!--ThisfileappenderisusedtooutputaggregatedperformancestatisticsinaformatidenticaltothatproducedbytheLogParser.--><appendername="fileAppender"class="org.apache.log4j.FileAppender"><paramname="File"value="perfStats.log"/><layoutclass="org.apache.log4j.PatternLayout"><paramname="ConversionPattern"value="%m%n"/></layout></appender><!--ThisJMXappendercreatesanMBeanandpublishesittotheplatformMBeanserverbydefault.--><appendername="perf4jJmxAppender"class="org.perf4j.log4j.JmxAttributeStatisticsAppender"><!--ThetagnameswhosestatisticsshouldbeexposedasMBeanattributes.--><paramname="TagNamesToExpose"value="firstBlock,secondBlock"/><!--TheNotificationThresholdsparamconfiguresthesendingofJMXnotificationswhenstatisticvaluesexceedspecifiedthresholds.ThisconfigstatesthatthefirstBlockmaxvalueshouldbebetween0and800ms,andthesecondBlockmaxvalueshouldbelessthan1500ms.YoucanalsosetthresholdsontheMin,Mean,StdDev,CountandTPSstatistics-e.g.firstBlockMean(<600).--><paramname="NotificationThresholds"value="firstBlockMax(0-800),secondBlockMax(<1500)"/></appender><!--Loggers--><!--ThePerf4Jlogger.--><loggername="org.perf4j.TimingLogger"additivity="false"><levelvalue="INFO"/><appender-refref="CoalescingStatistics"/></logger><!--TherootloggersendsalllogstatementsEXCEPTthosesenttotheperf4jloggertoSystem.out.--><root><levelvalue="INFO"/><appendername="console"class="org.apache.log4j.ConsoleAppender"><layoutclass="org.apache.log4j.SimpleLayout"/></appender></root></log4j:configuration>
复制代码
除JMX插件,Perf4J也撑持天生功能图表的绘图appender,利用前真个Perf4J绘图Servlet。定制的csv结构能够轻松的导进Excel大概其他电子表格使用。
利用@Profiled注解简化功能日记

在代码中增添功能纪录语句(一般的日记语句)的一个弱点是下降了代码的“信噪比”,难以在特定代码块中遵守严厉的营业逻辑。为了改良这一不敷,Perf4J供应了@Profiled注解,能够增加在必要纪录实行工夫的办法上,同意办法自己不增加StopWatch代码:
  1. @Profiled(tag="dynamicTag_{$0}")publicvoidprofiledExample(StringtagSuffix){...businesslogiconlyhere}
复制代码
一旦增加了@Profiled注解,Perf4J的计时切面会经由过程一个面向切面的编程框架如AspectJ大概SpringAOP启用。这个切面在办法挪用四周到场创建和中断StopWatch实例的字节码。计时切面乃至能够有选择的利用AspectJ的加载时编织(load-timeweaving)功效。因而,经由过程利用加载时编织你能够包管那些没有启用功能监控的办法尽没有分外的包袱。
一个复杂的示例:基于Web的质数天生器

本示例将带你感觉怎样创立一个利用Perf4J库年夜多半功效的实在使用。你能够下载perf4jPrimes.war文件,然后Servlet容器中运转它。在war包中也包括该使用的源代码。
统统从简,本例子只包括两个次要的代码文件:primes.jsp用于显现天生的质数和承受用户指定的参数,PrimeNumberGenerator类包括真实的天生代码(年夜部分托付给java.math.BigInteger类)。个中有三处利用了Perf4J计时期码块:
假如检察WEB-INF/classes/log4j.xml文件,你会看到启用了上面的Perf4功效:
一旦在Web服务器上启动了该Web使用,你就能够经由过程http://servername/<rootContextLocation>/primes.jsp会见质数天生页面,个中rootContextLocation由你的Web服务器设置决意(固然,为了便利,你也能够经由过程http://servername/<rootContextLocation>/PrimeNumberGenerator.java检察PrimeNumberGenerator源代码)。在primes.jsp页面中,你会看到良多用于质数天生的分歧参数。你能够改动参数,然后点击“天生质数”按钮,看看这些参数是怎样影响质数发生工夫的。在天生大批质数以后,你能够经由过程三种路子来检察Perf4J输入:
由于到如今为止你还没有启用任何TimingAspects撑持@Profiled注解,你可以看到的独一stopwatch输入就是“fullPageGeneration”标志。假如要启用TimingAspects,你可使用AspectJ加载时编织。你必要做的是,在启动Web服务器时利用AspectJweaving代办署理命令行参数:
  1. -javaagent:/path/to/aspectjweaver-1.6.1.jar
复制代码
你能够在这里下载jar包:http://mirrors.ibiblio.org/pub/mirrors/maven2/org/aspectj/aspectjweaver/1.6.1/aspectjweaver-1.6.1.jar
今世理启用时,你能够在“generatePrime”和“randomFromRandomDotOrg”标志中看到stopwatch的输入。
圈套与最好理论

良多监控使用的办法,不管是针对功能、不乱性仍是语义准确性,都没法最无效的表现它们的企图。要末天生了太多的信息以致于难以剖析这些数据,要末在必要信息的中央却得不到关头的数据。固然一切的监控都必要一些分外的开支,可是功能监控应当对这些引进的开支分外当心。以下倡议能够匡助你最年夜限制天时用Perf4J,同时又将反作用降到最低:
瞻望Perf4J

Perf4J今朝正在主动的开展,新的功效层见叠出。举例来讲,依附新版本的Perf4J,我们能够经由过程独自的设置文件指定要剖析的办法,如许即便没法取得某些办法的源代码也能够对其举行计时。我们一直将用户的反应和需求放在第一名,假如你想打造它将来的功效,那如今就来实验Perf4J吧。更主要的是,Perf4J在Apache2协定下完整开源,代码都充实文档化,你能够随便扩大。
如今就下载Perf4J吧,告知我们你的设法!
检察英文原文:PerformanceAnalysisandMonitoringwithPerf4J
本文来自:http://www.infoq.com/cn/articles/perf4j

大型的应用一般不会用这些框架(因为性能考虑);开发人员根据需要选择用一些框架,也可以不选用框架;不用框架并不代表要自己写框架;修改框架的可能性更小。
作者: 透明    时间: 2015-1-20 06:03
《JAVA语言程序设计》或《JAVA从入门到精通》这两本书开始学,等你编程有感觉的时候也可以回看一下。《JAVA读书笔记》这本书,因为讲的代码很多,也很容易看懂,涉及到面也到位。是你学习技术巩固的好书,学完后就看看《JAVA编程思想》这本书,找找一个自己写的代码跟书上的代码有什么不一样。
作者: 小女巫    时间: 2015-1-24 14:27
Java是一个纯的面向对象的程序设计语言,它继承了 C++语言面向对象技术的核心。Java舍弃了C ++语言中容易引起错误的指针(以引用取代)、运算符重载(operator overloading)
作者: 愤怒的大鸟    时间: 2015-1-25 10:15
另外编写和运行Java程序需要JDK(包括JRE),在sun的官方网站上有下载,thinking in java第三版用的JDK版本是1.4,现在流行的版本1.5(sun称作J2SE 5.0,汗),不过听说Bruce的TIJ第四版国外已经出来了,是专门为J2SE 5.0而写的。
作者: 再现理想    时间: 2015-1-26 21:15
一直感觉JAVA很大,很杂,找不到学习方向,前两天在网上找到了这篇文章,感觉不错,给没有方向的我指了一个方向,先不管对不对,做下来再说。
作者: 兰色精灵    时间: 2015-1-28 19:43
如果要向java web方向发展也要吧看看《Java web从入门到精通》学完再到《Struts2.0入门到精通》这样你差不多就把代码给学完了。有兴趣可以看一些设计模块和框架的包等等。
作者: 爱飞    时间: 2015-2-3 12:10
所以现在应用最广泛又最好学的就是J2EE了。 J2EE又包括许多组件,如Jsp,Servlet,JavaBean,EJB,JDBC,JavaMail等。要学习起来可不是一两天的事。那么又该如何学习J2EE呢?当然Java语法得先看一看的,I/O包,Util包,Lang包你都熟悉了吗?然后再从JSP学起。
作者: 金色的骷髅    时间: 2015-2-8 20:54
我大二,Java也只学了一年,觉得还是看thinking in java好,有能力的话看英文原版(中文版翻的不怎么好),还能提高英文文档阅读能力。
作者: 只想知道    时间: 2015-2-24 04:42
接着就是EJB了,EJB就是Enterprise JavaBean, 看名字好象它是Javabean,可是它和Javabean还是有区别的。它是一个体系结构,你可以搭建更安全、更稳定的企业应用。它的大量代码已由中间件(也就是我们常听到的 Weblogic,Websphere这些J2EE服务器)完成了,所以我们要做的程序代码量很少,大部分工作都在设计和配置中间件上。
作者: 冷月葬花魂    时间: 2015-2-28 19:04
是一种语言,用以产生「小应用程序(Applet(s))
作者: 若天明    时间: 2015-3-2 09:30
吧,现在很流行的Structs就是它的一种实现方式,不过Structs用起来实在是很繁,我们只要学习其精髓即可,我们完全可以设计自己的MVC结构。然后你再研究一下软件Refactoring (重构)和极限XP编程,相信你又会上一个台阶。 做完这些,你不如整理一下你的Java代码,把那些经典的程序和常见的应用整理出来,再精心打造一番,提高其重用性和可扩展性。你再找几个志同道合的朋友成立一个工作室吧
作者: 蒙在股里    时间: 2015-3-6 22:44
J2SE开发桌面应用软件比起 VC,VB,DEPHI这些传统开发语言来说,优势好象并不明显。J2ME对于初学者来说,好象又有点深奥,而且一般开发者很难有开发环境。
作者: 若相依    时间: 2015-3-11 11:44
是一种简化的C++语言 是一种安全的语言,具有阻绝计算机病毒传输的功能
作者: admin    时间: 2015-3-16 05:00
科学超级计算机、移动电话和互联网,同时拥有全球最大的开发者专业社群。
作者: 再见西城    时间: 2015-3-20 04:38
所以现在应用最广泛又最好学的就是J2EE了。 J2EE又包括许多组件,如Jsp,Servlet,JavaBean,EJB,JDBC,JavaMail等。要学习起来可不是一两天的事。那么又该如何学习J2EE呢?当然Java语法得先看一看的,I/O包,Util包,Lang包你都熟悉了吗?然后再从JSP学起。
作者: 山那边是海    时间: 2015-3-21 13:03
吧,现在很流行的Structs就是它的一种实现方式,不过Structs用起来实在是很繁,我们只要学习其精髓即可,我们完全可以设计自己的MVC结构。然后你再研究一下软件Refactoring (重构)和极限XP编程,相信你又会上一个台阶。 做完这些,你不如整理一下你的Java代码,把那些经典的程序和常见的应用整理出来,再精心打造一番,提高其重用性和可扩展性。你再找几个志同道合的朋友成立一个工作室吧
作者: 灵魂腐蚀    时间: 2015-3-23 11:01
Java语言支持Internet应用的开发,在基本的Java应用编程接口中有一个网络应用编程接口(java net),它提供了用于网络应用编程的类库,包括URL、URLConnection、Socket、ServerSocket等。Java的RMI(远程方法激活)机制也是开发分布式应用的重要手段。
作者: 仓酷云    时间: 2015-4-1 17:11
《JAVA语言程序设计》或《JAVA从入门到精通》这两本书开始学,等你编程有感觉的时候也可以回看一下。《JAVA读书笔记》这本书,因为讲的代码很多,也很容易看懂,涉及到面也到位。是你学习技术巩固的好书,学完后就看看《JAVA编程思想》这本书,找找一个自己写的代码跟书上的代码有什么不一样。
作者: 第二个灵魂    时间: 2015-4-12 22:34
在全球云计算和移动互联网的产业环境下,Java更具备了显著优势和广阔前景。
作者: 简单生活    时间: 2015-4-12 23:36
当然你也可以参加一些开源项目,一方面可以提高自己,另一方面也是为中国软件事业做贡献嘛!开发者在互联网上用CVS合作开发,用QQ,MSN,E-mail讨论联系,天南海北的程序员分散在各地却同时开发同一个软件,是不是很有意思呢?
作者: 变相怪杰    时间: 2015-4-21 02:20
多重继承(以接口取代)等特性,增加了垃圾回收器功能用于回收不再被引用的对象所占据的内存空间,使得程序员不用再为内存管理而担忧。在 Java 1.5 版本中,Java 又引入了泛型编程(Generic Programming)、类型安全的枚举、不定长参数和自动装/拆箱等语言特性。




欢迎光临 仓酷云 (http://ckuyun.com/) Powered by Discuz! X3.2