perf4j使用四(log4j集成圖表查看)

           

          在使用二這編文章中提到,可以以匯總形式查看日志,也可以通過圖表來查看。Perf4jlog4j集成后,其實也可以以圖表的形式來查看性能狀況。

           

          我們這篇文章還是使用前一篇文章中提到log4j.xml的配置,其他都一樣,只是在配置中加入了圖表的配置:

          <!-- 生成firstBlock,secondBlock的平均值的圖表 -->

              <appender name="graphExecutionTimes"

                        class="org.perf4j.log4j.GraphingStatisticsAppender">

                  <!-- GraphType:Mean(平均值), Min(最小值), Max(最大值), TPS(每秒事務數) -->

                  <param name="GraphType" value="Mean"/>

                  <param name="TagNamesToGraph" value="firstBlock,secondBlock"/>

                  <appender-ref ref="graphsFileAppender"/>

              </appender>

           

              <!-- 生成firstBlock,secondBlocktps的圖表 -->

              <appender name="graphExecutionTPS"

                        class="org.perf4j.log4j.GraphingStatisticsAppender">

                  <param name="GraphType" value="TPS"/>

                  <param name="TagNamesToGraph" value="firstBlock,secondBlock"/>

                  <appender-ref ref="graphsFileAppender"/>

              </appender>

             

              <!-- 記錄圖表生成urllog文件 -->

              <appender name="graphsFileAppender" class="org.apache.log4j.FileAppender">

                  <param name="File" value="/home/perfGraphs.log"/>

                  <layout class="org.apache.log4j.PatternLayout">

                      <param name="ConversionPattern" value="%m%n"/>

                  </layout>

          </appender>

          另外還需要改一個地方,就是CoalescingStatistics的配置:

          <appender name="CoalescingStatistics"

                        class="org.perf4j.log4j.AsyncCoalescingStatisticsAppender">

                  <!--

                       TimeSlice配置多少時間間隔去做一次匯總寫入文件中

                       默認值是 30000 ms

                  -->

                  <param name="TimeSlice" value="10000"/>

                  <appender-ref ref="fileAppender"/>

                 

                  <appender-ref ref="graphExecutionTimes"/>

                  <appender-ref ref="graphExecutionTPS"/>

              </appender>

          黃色那段配置的意思就是把日志寫入到圖表日志去。

          運行代碼Perf4JAppenderExample,我們在perfGraphs.log文件中生成了圖表的url

          http://chart.apis.google.com/chart?cht=lxy&chtt=Mean&chs=750x400&chxt=x,x,y&chd=t:0.0,100.0|45.2,78.1|0.0,100.0|98.1,100.0&chco=ff0000,00ff00&chm=d,ff0000,0,-1,5.0|d,00ff00,1,-1,5.0&chdl=firstBlock|secondBlock&chxr=2,0,828.6&chxl=0:|13:23:50|13:24:00|1:|Time&chxp=0,0.0,100.0|1,50&chg=50.0,10

           

          http://chart.apis.google.com/chart?cht=lxy&chtt=TPS&chs=750x400&chxt=x,x,y&chd=t:0.0,100.0|100.0,100.0|0.0,100.0|100.0,100.0&chco=ff0000,00ff00&chm=d,ff0000,0,-1,5.0|d,00ff00,1,-1,5.0&chdl=firstBlock|secondBlock&chxr=2,0,0.5&chxl=0:|13:23:50|13:24:00|1:|Time&chxp=0,0.0,100.0|1,50&chg=50.0,10

          大家可以把url放到瀏覽器訪問下。

           

          上面這種方式呢,需要自己登錄到服務器上,找到log文件,在放到瀏覽器中查看,總的過程還是比較麻煩。如果大家需要監控的工程是一個web工程的話,那就更方便了,直接配置一個servlet來查看。Web.xml的配置如下:

          <!DOCTYPE web-app PUBLIC

           "-//Sun Microsystems, Inc.//DTD Web Application 2.3//EN"

           "http://java.sun.com/dtd/web-app_2_3.dtd" >

           

          <web-app>

              <display-name>Archetype Created Web Application</display-name>

           

              <servlet>

                 <servlet-name>perf4j</servlet-name>

                 <servlet-class>org.perf4j.log4j.servlet.GraphingServlet</servlet-class>

                 <!-- graphExecutionTimesgraphExecutionTPS就是我們在log4j中配置的名稱 -->

                 <init-param>

                     <param-name>graphNames</param-name>

                     <param-value>graphExecutionTimes,graphExecutionTPS</param-value>

                 </init-param>

              </servlet>

           

              <servlet-mapping>

                 <servlet-name>perf4j</servlet-name>

                 <url-pattern>/perf4j</url-pattern>

              </servlet-mapping>

          </web-app>

          大家可以打包工程,并放到web服務器下啟動,然后訪問下/perf4j這個uri

          Maven有一個jetty插件,可以方便啟動web工程,只要大家在pom.xml文件中加入如下配置:

          <plugins>

                     <!-- jetty插件, 設定端口與context path-->

                     <plugin>

                        <groupId>org.mortbay.jetty</groupId>

                        <artifactId>jetty-maven-plugin</artifactId>

                     </plugin>    

          </plugins>

          在控制臺中輸入:mvn jetty:run,即可。省去了打包發布,很省心喔。

          第一次用http://localhost:8080/perf4j訪問查看圖表的時候沒有生成任何東西,那是因為內存中沒有收集到最新的性能數據。所以我在index.jsp里調用下以便產生性能數據。然后重新訪問,這個時候就有圖表生成了。


          下載工程

          posted on 2012-04-19 14:12 yangpingyu 閱讀(1747) 評論(1)  編輯  收藏 所屬分類: java基礎

          評論

          # re: perf4j使用四(log4j集成圖表查看)[未登錄] 2015-12-18 12:01 peter

          xiedezhenhao,  回復  更多評論   

          <2012年4月>
          25262728293031
          1234567
          891011121314
          15161718192021
          22232425262728
          293012345

          導航

          統計

          常用鏈接

          留言簿

          隨筆分類

          隨筆檔案

          收藏夾

          linux

          產品交互

          分析,設計,架構

          安全

          技術牛人

          數據庫

          搜索

          最新評論

          閱讀排行榜

          評論排行榜

          主站蜘蛛池模板: 北票市| 西林县| 财经| 昌平区| 云和县| 于都县| 桃园市| 建阳市| 教育| 白沙| 赤峰市| 富顺县| 海原县| 江陵县| 汉源县| 营山县| 天津市| 祁连县| 荣昌县| 连城县| 西乌珠穆沁旗| 伊通| 沙雅县| 濉溪县| 藁城市| 威远县| 延吉市| 连山| 潍坊市| 房产| 雷州市| 石柱| 句容市| 普兰县| 东宁县| 长葛市| 桂平市| 眉山市| 金川县| 衡阳县| 田东县|