(七):性能监测工具JavaMelody
最后更新于:2022-04-01 07:00:00
# (七):性能监测工具JavaMelody
### 简介
JavaMelody 能够监测Java或Java EE应用程序服务器,并以图表的方式显示:
Java内存和Java CPU使用情况,用户Session数量,JDBC连接数,
和http请求、sql请求、jsp页面与业务接口方法(EJB3、Spring、 Guice)的执行数量,平均执行时间,错误百分比等。
图表可以按天,周,月,年或自定义时间段查看。
### 使用步骤
1.下载JavaMelody。
下载地址:[http://code.google.com/p/javamelody/downloads/list](http://code.google.com/p/javamelody/downloads/list)
javamelody-1.16.0.jar,jrobin-1.5.9.1.jar
(版本号可能会不同)
2.将Jar包拷贝到项目的WEB-INF的lib目录。
3.在web.xml下增加配置。
~~~
<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>
~~~
4.重新启动项目,访问[http://localhost:8080/monitoring/](http://localhost:8080/monitoring/) 即可看到监控图表。
[![](image/569357debac20.gif)](http://fansunion.cn/wp-content/uploads/2013/11/Jamelody%E5%9B%BE%E8%A1%A8.gif)
### 安全问题
按照上述的配置,不需要登录就可以访问JavaMelody的页面。
实际项目中,常见需求是“登录用户,才可以查看”。
定制方法如下:
web.xml的Filter配置
packageName.ProjectMonitoringFilter
自定义的Filter
~~~
public class ProjectMonitoringFilter extends net.bull.javamelody.MonitoringFilter{
@Override
public void doFilter(ServletRequest req, ServletResponse response,
FilterChain chain) throws IOException, ServletException {
HttpServletRequest request = (HttpServletRequest) req;
HttpSession session = request.getSession();
User user = (User) session.getAttribute(Constant.LOGIN_USER);
String uri = ((HttpServletRequest) request).getRequestURI();
if(user == null && uri.indexOf("/monitoring") != -1){
return;
}
super.doFilter(request, response, chain);
}
}
~~~
### 实践出真知
本来想自己总结的,发现别人总结的比我好,所以就借鉴了许多别人写的。
我觉得“借鉴”和“复制”别人的并不可耻,因为绝大部分技术都是别人开发的,我们只是用。
那些技术的优点、正确的使用方法,基本是固定的了,我们只有学习的份。
这类工具的使用方法,网上一大堆。
不过,自己总结下,加深下理解,今后也有自己的参考。
看自己总结的,更亲切,更可读,出错的可能性更小。