2013-07-18 3 views
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 주석은 아무 효과가없는 것처럼 보입니다.

답변

0

시도 :

<!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"/> 

     <!-- Weave in perf4j aspects for Aspectj 1.6.7+ --> 
     <include within="org.perf4j.slf4j.aop.*"/> 
     <include within="org.perf4j.aop.*"/> 
    </weaver> 

</aspectj>