美文网首页
【Java监控系列】用javamelody监控java应用

【Java监控系列】用javamelody监控java应用

作者: 带着二娃去遛弯 | 来源:发表于2019-05-05 09:03 被阅读0次

javamelody是用来监控java项目的,和之前介绍的psi-probe不同,javamelody只能监控一个项目,也就是说,你的每个项目都需要一个javamelody,它是一个jar包,你也可以理解成一个插件。

它提供一些图表让你知道项目的运行情况,可以按天、周、月、年、全部(从运行至今)来查看监控信息。这些信息是持久化的,保存在tomcat的temp目录下,里面有一些rrd文件。

对我来说,其最大的用处是用来监控sql,本文主要讲spring集成javamelody。如果本文不能对你提供帮助,请尝试阅读项目UserGuide或者项目GitHub地址

UserGuide里面还包括了javamelody和hibernate集成、安全管理器,真实用户体验等内容,由于我暂时用不到,没深入研究,在此抛砖引玉。

image

本文环境:JDK8 ( javamelody要求JDK6以上 ) + apache-tomcat-7.0.88 + Spring 4.1.4 + javamelody1.71.0,数据库用的是Spring自带的JdbcTemplete

安装

添加依赖jar包

这里我用的是gradle,javamelody版本是1.71.0,下面也有maven依赖。

//gradle 
compile group: 'net.bull.javamelody', name: 'javamelody-core', version: '1.71.0'

//maven
<dependency>
    <groupId>net.bull.javamelody</groupId>
    <artifactId>javamelody-core</artifactId>
    <version>1.71.0</version>
</dependency>

配置web.xml

这里需要注意的是官方说如果servlet API版本是在3.0以上的可以不用再web.xml里面配置东西,因为3.0以上支持模块化,即javamelody的jar包就是一个模块,jar包里面的META-INF/web-fragment.xml配置了启动javamelody的相关信息。

查看web.xml是否有声明版本信息比如version="3.0"就知道是什么版本。

我的web.xml声明的是version="3.1",按理说不用配置什么也能开启,但是第一次失败,我在web.xml里面配置了相关的filter/listener才开启,后来我又注释掉了依然可以用,反正,如果开启不了,加上一下配置信息试一下。

而且,javamelody的web-fragment.xml配置默认是不带登录验证的,这样谁都可以访问,及其不安全,下面的配置带登录验证。

<!--javamelody 监控项目-->
<filter>
    <filter-name>javamelody</filter-name>
    <filter-class>net.bull.javamelody.MonitoringFilter</filter-class>
    <async-supported>true</async-supported>
    <init-param>
        <!--添加登录验证,默认是不带登录验证的-->
        <param-name>authorized-users</param-name>
        <param-value>tomcat1:1, tomcat2:2</param-value>
    </init-param>
</filter>
<filter-mapping>
    <filter-name>javamelody</filter-name>
    <url-pattern>/*</url-pattern>
    <!--用来开启异步调用-->
    <dispatcher>REQUEST</dispatcher>
    <dispatcher>ASYNC</dispatcher>
</filter-mapping>
<listener>
    <listener-class>net.bull.javamelody.SessionListener</listener-class>
</listener>

下面是和Spring集成,监控JDBC的配置,在Spring的监听器里面将javamelody的sql监控配置加进去。

<listener>
    <listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>
</listener>
<context-param>
    <param-name>contextConfigLocation</param-name>
    <param-value>
        classpath:net/bull/javamelody/monitoring-spring.xml<!--javamelody和spring集成用来监控SQL-->
        classpath*:spring-core.xml
    </param-value>
</context-param>

开启

最后访问http://ip:port/{你的应用名字}/monitoring,输入上文web.xml里面配置的账号和密码。

  • 主页面,上面可以选择时间段

    image
  • http监控,可以查看请求接口的信息

    image
  • sql监控,查看sql执行信息

    image
  • http错误信息,鼠标移上去会有错误详情

    image
  • 系统错误信息,鼠标移上去会有应用详情

    image
  • 下面是系统和线程的信息

    image

作者:代码狂魔
链接:https://www.jianshu.com/p/69524fd86832
来源:简书
简书著作权归作者所有,任何形式的转载都请联系作者获得授权并注明出处。

相关文章

网友评论

      本文标题:【Java监控系列】用javamelody监控java应用

      本文链接:https://www.haomeiwen.com/subject/cpaqoqtx.html