JavaMelody可以在運行環境監測Java或Java EE應用程序服務器。並以圖表的形式顯示:Java內存和Java CPU使用狀況,用戶Session數量,JDBC鏈接數,和http請求、sql請求、jsp頁面與業務接口方法(EJB三、Spring、Guice)的執行數量,平均執行時間,錯誤百分比等。圖表能夠按天,周,月,年或自定義時間段查看。 html
監控效果圖見本文結尾部分. java
3.在web.xml中配置filter: web
<filter> <filter-name>monitoring</filter-name> <filter-class>net.bull.javamelody.MonitoringFilter</filter-class> <init-param> <param-name>log</param-name> <param-value>true</param-value> </init-param> </filter> <filter-mapping> <filter-name>monitoring</filter-name> <url-pattern>/*</url-pattern> </filter-mapping> <listener> <listener-class>net.bull.javamelody.SessionListener</listener-class> </listener>4.重啓項目:打開連接:http://<host>:<port>/projectname/monitoring
至此,基本配置已完成,能夠進行簡單的性能監控,下面配置是javamelody與struts2和spring3的集成配置: 正則表達式
<package name="base" namespace="/" extends="struts-default"> <result-types> <result-type name="json" class="org.apache.struts2.json.JSONResult" /> </result-types> <interceptors> <!-- javamelody --> <interceptor name="monitoring" class="net.bull.javamelody.StrutsInterceptor" /> <interceptor-stack name="myStack"> <interceptor-ref name="monitoring" /> <!-- struts默認的攔截器 --> <interceptor-ref name="defaultStack" /> </interceptor-stack> </interceptors> <default-interceptor-ref name="myStack" />其餘struts配置文件繼承base,以下所示:
<package name="example" namespace="/" extends="base"> <action name="student_*" class="studentAction" method="{1}"> <result name="input">/pub_error.jsp</result> </action> </package>
<bean id= "facadeMonitoringAdvisor" class="net.bull.javamelody.MonitoringSpringAdvisor" > <property name ="pointcut" > <bean class="org.springframework.aop.support.JdkRegexpMethodPointcut" > <property name ="pattern" value="com.proj.*.service.*" /><!--正則表達式--> </bean> </property> </bean>而後配置:
7.若是你的全部spring管理的bean都實現了接口,用步驟6中的配置一切OK,但若是有些bean沒有實現接口,使用步驟6中的配置將會出錯.
則將步驟6中的配置改成(這樣將使用cglib代理):
spring配置文件中配置:
<bean id= "facadeMonitoringAdvisor" class="net.bull.javamelody.MonitoringSpringAdvisor" >
<property name ="pointcut" >
<bean class="org.springframework.aop.support.JdkRegexpMethodPointcut" >
<property name ="pattern" value="com.proj.*.service.*" /><!--正則表達式-->
</bean>
</property>
</bean>
方式一,web.xml中加入以下配置:
<context-param>
<param-name> contextConfigLocation</param-name>
<param-value>
classpath:applicationContext*.xml<!--Spring配置文件-->
classpath:net/bull/javamelody/monitoring-spring-aspectj.xml<!--和spring集成時添加-->
</param-value>
</context-param>
方式二,在spring.xml中加入以下配置:
<import resource="classpath:net/bull/javamelody/monitoring-spring-aspectj.xml" />
spring
8.在項目中常常這樣獲得泛型類: sql
private Class<T> entityClass = (Class<T>) ((ParameterizedType) getClass() .getGenericSuperclass()).getActualTypeArguments()[0];使用步驟7配置的cglib代理後會以上代碼會出錯,能夠改成下面這種方式獲得泛型類:
private Class<T> entityClass = (Class<T>) getSuperClassGenricType(this .getClass(), 0); public static Class<?> getSuperClassGenricType(Class<?> clazz, int index) throws IndexOutOfBoundsException { Type genType = clazz.getGenericSuperclass(); if (!(genType instanceof ParameterizedType)) { return Object.class; } Type[] params = ((ParameterizedType) genType).getActualTypeArguments(); if (index >= params.length || index < 0) { return Object.class; } if (!(params[index] instanceof Class<?>)) { return Object.class; } return (Class<?>) params[index]; }
<bean id="quartzScheduler" class="org.springframework.scheduling.quartz.SchedulerFactoryBean"> <property name="exposeSchedulerInRepository" value="true" /> ... </bean>12.javamelody中配置可選參數:
<filter> <filter-name>monitoring</filter-name> <filter-class>net.bull.javamelody.MonitoringFilter</filter-class> <init-param> <param-name>log</param-name> <param-value>true</param-value> </init-param> </filter>其餘可選參數:
更多內容請參考:http://code.google.com/p/javamelody/wiki/UserGuide apache
效果圖: json