JavaMelody 監控java項目

jopen 10年前發布 | 44K 次閱讀 Java開發 JavaMelody

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&nbsp;

<host>:為你的主機名+端口地址 
<context>:為你的應用配置地址 

根據上面的情況,實際運行結果如下: 

JavaMelody 監控java項目


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>

 本文由用戶 jopen 自行上傳分享,僅供網友學習交流。所有權歸原作者,若您的權利被侵害,請聯系管理員。
 轉載本站原創文章,請注明出處,并保留原始鏈接、圖片水印。
 本站是一個以用戶分享為主的開源技術平臺,歡迎各類分享!