您是否在Java应用程序中使用Perf4J来收集和分析性能统计信息?
典型模式是什么(使用日志文件,实用程序,UI,JMX等)?
您是否使用了注释和基于AOP的功能?
您使用过任何JMX集成吗?
您是如何处理生产配置的?
您是否将效果统计信息视图/报告作为应用中的功能包含在内?
请告诉您是否以及为何选择了替代图书馆/方法。
答案 0 :(得分:11)
我使用Per4j来监控Web服务端点性能以及内部服务和dao类性能。
我主要只是将原始性能统计信息记录到每日滚动文件中。然后我在命令行上使用jar来分析具有不同时间片的数据。我经常使用-g
命令行选项输出一个html文件,然后我可以打开它并直观地查看数据,这非常有用。
我喜欢使用带有@Profiled
注释的Spring AOP。它使时间非常干净。我有一些关于perf4j降级性能的怀疑者,我可以轻松地提出我可以通过从我的Spring applicationContext.xml文件中删除TimingAspect
来关闭日志记录。
<!-- just remove and all uses of @Profiled do nothing -->
<bean id="timingAspect" class="org.perf4j.log4j.aop.TimingAspect"/>
关于平均值并注意最大值。在进行性能调整时,我们进行了一个方法调用,其中包含具有较大标准偏差的Wild值。大多数值都在中位数附近,但有一些电话比平均值高出100倍。比任何事情都更多的用户错误,但要注意。
我使用时间间隔为15000的AsyncCoalescingStatisticsAppender
,但很难读取日志。因为我有原始的性能日志,所以我可以通过在命令行上运行perf4j来进行切换和更改。
我尝试了JMX集成,它按照文档中的承诺运行。但我目前没有真正的用途。
我计划使用SNMP公开数据,如果它有用,我会做出贡献。
总之,我推荐Perf4j。
答案 1 :(得分:7)
我在客户端 - 服务器应用程序中使用Perf4J来定时RPC调用。它实现起来非常简单:我只需要在RPC调度程序servlet中包含几行代码来测量每个RPC方法调用。时间测量被写入单独的日志文件,聚合数据保存在内存中以供图形化servlet使用。配置只需几分钟。
这是preHandle()方法的摘录:
request.setAttribute("stopWatch", new CommonsLogStopWatch());
来自postHandle()方法的代码:
LoggingStopWatch stopWatch = (LoggingStopWatch)request.getAttribute("stopWatch");
stopWatch.stop(methodName);
以下是我的log4j.cfg的相关部分:
<logger name="org.perf4j.TimingLogger" additivity="false">
<level value="info"/>
<appender-ref ref="CoalescingStatistics"/>
<appender-ref ref="statsAppender"/>
</logger>
<appender name="CoalescingStatistics"
class="org.perf4j.log4j.AsyncCoalescingStatisticsAppender">
<param name="TimeSlice" value="60000"/>
<appender-ref ref="graphPatientChart"/>
</appender>
<appender name="graphPatientChart"
class="org.perf4j.log4j.GraphingStatisticsAppender">
<param name="GraphType" value="Mean"/>
<param name="TagNamesToGraph" value="getPatientChart,idleNotification"/>
</appender>
<appender name="statsAppender" class="org.apache.log4j.DailyRollingFileAppender">
<param name="datePattern" value="'.'yyyy-MM-dd"/>
<param name="file" value="WEB-INF/log/meona-performance.log"/>
<param name="append" value="true"/>
<layout class="org.apache.log4j.PatternLayout">
<param name="ConversionPattern" value="%m%n"/>
</layout>
</appender>
我希望图形化servlet更具交互性:如果我可以选择要包含在图形中的标记,那就太好了。您是否遇到过可用于分析时间测量日志的UI应用程序?
答案 2 :(得分:3)
我已经使用过Perf4J,最终因为我已经在使用Spring AOP而放弃了它。我很乐意简单地整合这两个,但是遇到了麻烦(因为Perf4J appenders)。
我尝试通过注释和没有JMX的AOP使用Perf4j。 您可以通过配置文件处理生产cfg。
总的来说,我喜欢Perf4j方法,但由于我已经使用Spring进行性能监控,所以我不需要perf4j。 Perf4j免费提供的一件事是最小/最大/标准开发;与其他图书馆一样,你必须自己做数学。
如果你没有任何其他可以提供拦截的lib(aspectJ或AOP),我的东西perf4j很好,但是因为我已经有了spring,所以实现性能测量更容易。您可以使用Spring通过JMX轻松公开bean属性。