0
다음과 같은 문제점이 있습니다. perf4j @Profiled annotation 및 log4j를 사용하여 성능이 낮은 메소드의 실행 시간을 모니터하고 싶습니다. 문제는 모니터링 로그 파일이 비어 있고 다음과 같습니다Perf4J @Profiled annotation + log4j가 작동하지 않습니다.
의 log4j.xml은 projectRoot/conf의/특급 디렉토리에 포함이처럼 보이는Performance Statistics 2013-07-17 18:07:50 - 2013-07-17 18:08:00
Tag Avg(ms) Min Max Std Dev Count
Performance Statistics 2013-07-17 18:08:00 - 2013-07-17 18:08:10
Tag Avg(ms) Min Max Std Dev Count
: 내가 가지고
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE log4j:configuration SYSTEM "log4j.dtd"><log4j:configuration xmlns:log4j="http://jakarta.apache.org/log4j/">
<appender name="stdout" class="org.apache.log4j.ConsoleAppender">
<layout class="org.apache.log4j.PatternLayout">
<param name="ConversionPattern" value="%d{ABSOLUTE} %5p %c{1}:%L - %m%n"/>
</layout>
</appender>
<appender name="logfile" class="org.apache.log4j.DailyRollingFileAppender">
<param name="File" value="./logs/exp-log.txt"/>
<param name="DatePattern" value="'.'yyyy-MM-dd-HH"/>
<layout class="org.apache.log4j.PatternLayout">
<param name="ConversionPattern" value="%p %d{HH:mm:ss.SSS} %c %m%n"/>
</layout>
</appender>
<appender name="CoalescingStatistics"
class="org.perf4j.log4j.AsyncCoalescingStatisticsAppender">
<param name="TimeSlice" value="10000"/>
<appender-ref ref="fileAppender"/>
<appender-ref ref="graphExecutionTimes"/>
<appender-ref ref="graphExecutionTPS"/>
</appender>
<appender name="fileAppender" class="org.apache.log4j.FileAppender">
<param name="File" value="./logs/perfStats.log"/>
<layout class="org.apache.log4j.PatternLayout">
<param name="ConversionPattern" value="%m%n"/>
</layout>
</appender>
<appender name="graphExecutionTimes"
class="org.perf4j.log4j.GraphingStatisticsAppender">
<!-- Possible GraphTypes are Mean, Min, Max, StdDev, Count and TPS -->
<param name="GraphType" value="Mean"/>
<!-- The tags of the timed execution blocks to graph are specified here -->
<param name="TagNamesToGraph" value="firstBlock,secondBlock"/>
<appender-ref ref="graphsFileAppender"/>
</appender>
<appender name="graphExecutionTPS"
class="org.perf4j.log4j.GraphingStatisticsAppender">
<param name="GraphType" value="TPS"/>
<param name="TagNamesToGraph" value="firstBlock,secondBlock"/>
<appender-ref ref="graphsFileAppender"/>
</appender>
<appender name="graphsFileAppender" class="org.apache.log4j.FileAppender">
<param name="File" value="./logs/perfGraphs.log"/>
<layout class="org.apache.log4j.PatternLayout">
<param name="ConversionPattern" value="%m%n"/>
</layout>
</appender>
<logger name="org.perf4j.TimingLogger" additivity="false">
<level value="INFO"/>
<appender-ref ref="CoalescingStatistics"/>
</logger>
<logger name="sui">
<level value="debug"/>
</logger>
<root>
<priority value="debug"/>
<appender-ref ref="logfile"/>
<appender-ref ref="stdout"/>
</root>
</log4j:configuration>
내 소스에 다음과 같은 주석 : 그 외에
@Profiled(tag = "exportRecsForAccount")
protected void exportRecsForAccount(NetSuiteAcctInfo acctInfo) {
@Profiled(tag = "exportRecsForEachAccount")
protected boolean exportRecsForEachAccount() throws QueueManagerException, CriticalDBConnectionFailed {
, 나는 projectRoot/recources/META-INF에있는 aop.xml을 가지고있다. 내용은 다음과 같습니다.
<!DOCTYPE aspectj PUBLIC "-//AspectJ//DTD//EN" "http://www.eclipse.org/aspectj/dtd/aspectj.dtd">
<aspectj>
<aspects>
<aspect name="org.perf4j.log4j.aop.TimingAspect"/>
</aspects>
<weaver options="-verbose -showWeaveInfo">
<include within="comp.sui.ExportService"/>
</weaver>
</aspectj>
여기서 comp.sui.ExportService는 소스 코드 클래스에 대한 링크입니다.
그래서 내가 뭘 잘못하고 있니? StopWatches 스탬프를 사용할 때 모든 것이 괜찮지 만 @Profiled 주석은 아무 효과가없는 것처럼 보입니다.