JavaMelody 監控java項目
javaMelody能夠在QA和實際運行生產環境監測Java或Java EE應用程序服務器。并以圖表的形式顯示:Java內存和Java CPU使用情況,用戶Session數量,JDBC連接數,和http請求、sql請求、jsp頁面與業務接口方法(EJB3、Spring、 Guice)的執行數量,平均執行時間,錯誤百分比等。圖表可以按天,周,月,年或自定義時間段查看javamelody 的配置非常簡單,你首先需要將 javamelody 的jar 文件打包到你的應用程序的 lib 目錄下。
然后修改 web.xml 中的過濾器。
下面就以我們自己的程序為例:
首先下載 javamelody 的分發包。
將下載文件中的 javamelody.jar 和 jrobin-x.jar 拷貝到你應用程序的 WEB-INF/lib 中。
修改過濾器配置。
官方的代碼為:
<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>
你能夠通過下面的 URL 訪問到程序運行情況。
http://<host>/<context>/monitoring
<host>:為你的主機名+端口地址
<context>:為你的應用配置地址
根據上面的情況,實際運行結果如下:

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):
<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參數中。
例如:
-Djavamelody.datasources=java:comp/env/myapp/MyDataSource
如果數據源定義在spring中, 如:
<bean class="org.apache.commons.dbcp.BasicDataSource">...</bean>
它也是可以被監控到的,利用Spring post-processor. 須確保Spring的配置文件 (net/bull/javamelody/monitoring-spring.xml ,包含在jar包中)被當作配置文件第一個加載.
例如:如果你在你的 web.xml中 配置了
org.springframework.web.context.ContextLoaderListener
那你的配置中應該配置參數:
<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>