<filter> <filter-name>monitoring</filter-name> <filter-class>net.bull.javamelody.MonitoringFilter</filter-class> </filter> <filter-mapping> <filter-name>monitoring</filter-name> <url-pattern>/*</url-pattern> </filter-mapping> <listener> <listener-class>net.bull.javamelody.SessionListener</listener-class> </listener>
JDBC
若是你的數據源命名爲"jdbc/MyDataSource", 而且配置在應用服務器 (webapp的context), 那麼你的sql請求會被自動監控而不須要任何參數(在 Tomcat 5.5 and 6, glassfish 3, jboss 5, weblogic 11g, jetty 6上測試經過).
若是你的JDBC驅動是無數據源直接使用的, 那你的驅動類應該定義爲:"net.bull.javamelody.JdbcDriver" ,而後應該加入jdbc屬性"driver"值爲真正的dirver class. 例如, 若是你使用的是hibernate.cfg.xml和mysql (無hibernate.connection.datasource): java
<property name ="hibernate.connection.driver_class" >net.bull.javamelody.JdbcDriver </property> <property name ="hibernate.connection.driver">com.mysql.jdbc.Driver</property> <property name="hibernate.connection.url"> jdbc:mysql://localhost:3306/myschema </property> <property nam="hibernate.connection.username">myuser</property> <property name="hibernate.connection.password">mypassword</property>
若是你使用了數據源可是名稱並不像"jdbc/MyDataSource"這樣,或者數據源沒有在一個日常的"java:comp/env/" 或者 "java:/"的JNDI 上下文中,那麼你能夠能夠增長可選參數「datasources」 (在system property或filter的上下文中) 去定義應用使用的數據源的JNDI. 若是有多個數據源,這個參數的值能夠用逗號分隔。 若是使用 的服務器是jonas V5,數據源能夠被監控,但如今看來,它們必須定義在 datasources參數中。
例如: mysql
-Djavamelody.datasources=java:comp/env/myapp/MyDataSource
若是數據源定義在spring中, 如: web
<bean class="org.apache.commons.dbcp.BasicDataSource">...</bean>
它也是能夠被監控到的,利用Spring post-processor. 須確保Spring的配置文件 (net/bull/javamelody/monitoring-spring.xml ,包含在jar包中)被看成配置文件第一個加載. spring
例如:若是你在你的 web.xml中 配置了 sql
org.springframework.web.context.ContextLoaderListener
那你的配置中應該配置參數: apache
<context-param> <param-name>contextConfigLocation </param-name> <param-value> classpath:net/bull/javamelody/monitoring-spring.xml classpath:context/services.xml classpath:context/data-access-layer.xml /WEB-INF/applicationContext.xml </param-value> </context-param>