1、问题背景
为了提升应用的性能我们可能需要做很多分析和优化。但具体从哪里优化,优化的效果是多少就难以判定了。
javamelody用嵌入式的监控方式,实时监控性能指标。如:页面相应时间,spring bean方法调用时间,sql语句执行时间等很多指标。我在这就不一一列举了。
我感觉比较好的两特点是:
会自动按命中次数与相应时间结合排序,这就可以知道优化哪个页面,bean方法,sql最有效果
页面,bean,sql自动关联,可钻取,点页面可以看页面中调用bean方法的情况,点bean方法可以看sql情况
2、配置步骤
a、引入依赖包
下载javamelody的jar文件,官方站点
https://code.google.com/p/javamelody/
中找到javamelody-1.40.0.jar下载下来
手动配置时还需要JRobin这个依赖,在
http://www.jrobin.org上下载
把这两这jar文件copy到你的lib中
如果采用maven配置
只需要在pom文件中加入
<dependency>
<groupId>net.bull.javamelody</groupId>
<artifactId>javamelody-core</artifactId>
<version>1.40.0</version>
</dependency>
同样的效果
b、修改web.xml文件
加入以下代码
<context-param>
<param-name>contextConfigLocation</param-name>
<param-value>
classpath:org/noahx/test/application-context.xml
[color=red]classpath:net/bull/javamelody/monitoring-spring.xml[/color]
</param-value>
</context-param>
<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>
spring采用org.springframework.web.context.ContextLoaderListener启动
注意filter-mapping的位置尽可能靠前,因为它来测相关请求时间
在你的spring配置文件位置中再加入classpath:net/bull/javamelody/monitoring-spring.xml这个配置
c、在spring配置的xml中加入Advisor
这样就可以监控spring bean的性能
<bean id="facadeMonitoringAdvisor" class="net.bull.javamelody.MonitoringSpringAdvisor">
<property name="pointcut">
<bean class="org.springframework.aop.support.JdkRegexpMethodPointcut">
<property name="patterns">
<array>
<value>org\.noahx\.test\..*</value>
</array>
</property>
</bean>
</property>
</bean>
org\.noahx\.test\..*为正则表达式,javamelody会自动匹配bean中的类名,来决定都监控哪些bean的哪些方法
我是监控了org.noahx.test下所有定义的spring bean的所有方法
d、sql与数据源监控
如果你的dateSource定义在spring中,javamelody会自动发现不需要额外配置。
e、运行测试
程序运行起来和原来并没有变化,还是和原来一样,可以多点一点你的页面。因为javamelody需要采集访问时的性能数据。然后你可以通过javamelody的url来查看你应用的性能指标。
http://host:port/你应用的上下文/monitoring。上下文后加monitoring这种格式就可以进入主面板查看结果。
------------------------------------------- 分割线 以下 是本人遇到错误,望哪位大侠伸出援助之手帮小弟解决------------------------------------------
PS:本人测试web.xml中配置
classpath:net/bull/javamelody/monitoring-spring.xml查看数据库JDBC和sql监控信息是总是提示失败。不配置不出错一切运行正常。
环境:
OS:windows XP
JAVA:JDK1.6.0.22
框架:Struts2+Spring2.5.6+Hibernate3.3
错误描述:
应用启动是报错误;
严重: Exception sending context initialized event to listener instance of class org.springframework.web.context.ContextLoaderListener
org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'dicCommonAction' defined in class path resource [actionContext.xml]: Error setting property values; nested exception is org.springframework.beans.NotWritablePropertyException: Invalid property 'dicAreaService' of bean class [com.utils.action.DicCommonAction]: Bean property 'dicAreaService' is not writable or has an invalid setter method. Does the parameter type of the setter match the return type of the getter?
相关配置文件:
web.xml
<context-param>
<param-name>contextConfigLocation</param-name>
<param-value>
classpath:net/bull/javamelody/monitoring-spring.xml,
classpath:applicationContext.xml,
classpath:serviceContext.xml,
classpath:actionContext.xml
</param-value>
</context-param>
serviceContext.xml和actionContext.xml合并显示
<bean id="dicAreaService" class="com.utils.service.DicCommonService" parent="baseService"/>
<!-- 下面是在actionContext.xml的配置 -->
<bean id="dicCommonAction" class="com.utils.action.DicCommonAction">
<property name="dicAreaService">
<ref bean="dicAreaService"/>
</property>
</bean>
原文地址:
http://my.oschina.net/noahxiao/blog/75463
分享到:
相关推荐
通过在Java Web应用中简单集成,JavaMelody就能提供包括请求处理时间、SQL查询、内存使用、线程信息、异常跟踪等多种关键性能指标的可视化报告。 首先,JavaMelody的核心功能在于其丰富的监控指标。它能够监控HTTP...
JavaMelody是一款强大的Java应用程序和应用服务器监控工具,它提供了实时的数据分析,帮助开发者和运维人员了解系统的健康状况和性能指标。通过图表形式展示内存使用、垃圾回收、Session管理、JDBC连接、SQL查询、...
- 然后,在web.xml中配置监听器和过滤器,启动JavaMelody监控。 - 配置完成后,只需访问特定URL(通常是/monitoring),即可访问监控界面。 3. **主要功能模块** - **性能监控**:展示HTTP请求的响应时间,分析...
总的来说,JavaMelody是一个强大且易于使用的Java Web应用性能监控工具,能够为开发者和运维团队提供宝贵的洞察力,确保应用的稳定性和高效运行。通过深入理解和有效利用JavaMelody,我们可以及时发现和解决潜在的...
JavaMelody是一款强大的Java应用程序性能监控工具,专为开发者和运维人员设计,用于实时监控Web应用的性能和健康状况。它能够集成到Spring、Struts、JSF等主流的Java Web框架中,提供包括请求时间、内存使用、数据库...
总的来说,JavaMelody是一款免费且功能齐全的Java应用性能监控解决方案,能够帮助开发者和运维团队提高故障排查效率,优化系统性能,是Java开发过程中不可或缺的辅助工具。通过持续监控和分析,可以及时发现并解决...
这个版本1.67.0包含了JavaMelody监控系统的最新特性和改进。 JavaMelody的主要功能在于提供实时的、详细的性能监控,它可以帮助开发者和运维人员了解应用的运行状态,及时发现并解决性能瓶颈。以下是一些关键知识点...
2. 配置`web.xml`,在你的Web应用上下文中注册JavaMelody的监听器和过滤器,以便拦截请求并收集监控数据。 3. 启动Tomcat服务器,然后在你的应用URL后面添加`/monitoring`路径,例如`http://yourapp.com/monitoring`...
JavaMelody是一款优秀的开源工具,主要用于监控Java Web应用的性能指标。它能够直观地展示应用程序的CPU使用率、内存消耗、请求处理数量等关键数据,并且支持对数据库访问(如JDBC调用)以及页面渲染时间进行跟踪...
JavaMelody通过收集和展示一系列关键指标,如请求处理时间、内存使用、数据库查询效率等,帮助优化应用性能并及时发现潜在的问题。 JavaMelody的核心功能包括: 1. **请求跟踪**:记录每个HTTP请求的处理时间和...
总之,`javamelody-core-1.52.0.jar`和`jrobin-1.5.9.jar`是JavaMelody监控解决方案的重要组成部分,它们共同为Java Web应用提供了详尽的性能监控和数据分析能力。通过集成这两个JAR,开发者可以轻松地对应用进行...
本资料包包含了搭建JavaMelody监控所需的全部组件和详细步骤,旨在为Java项目提供全面的健康检查。 首先,"javamelody所需资料包"中可能包含以下核心文件: 1. **javamelody-core**: 这是JavaMelody的核心库,提供...
`javamelody-collector-server-1.69.0.war` 是JavaMelody的收集器服务器,这是一个独立的Web应用程序,它可以部署在单独的服务器上,用于集中收集和展示多个JavaMelody监控实例的数据。通过这个服务,你可以监控分布...
1. **性能监控**:JavaMelody可以实时监控应用程序的请求处理时间、数据库查询性能、内存使用、线程状态等关键性能指标,帮助开发者快速定位性能瓶颈。 2. **错误和异常统计**:记录并展示应用程序中出现的错误和...
这将开启JavaMelody监控,并设置监控页面的访问路径为`/monitoring`,应用名为“我的应用名”。 在Spring Boot应用中,JavaMelody通常会自动配置,无需额外的编码工作。但在某些情况下,可能需要自定义配置,例如...
- 将`javamelody.jar`和`jrobin-x.jar`两个文件从提供的`javamelody.zip`压缩包根目录下复制到待监控Web应用的`WEB-INF/lib`目录中。 - 如果使用Maven构建工具,可以通过添加`javamelody-core`依赖项简化安装流程...
JavaMelody是一款强大的监控工具,专门用于监测Java Web应用程序的性能和使用情况。它通过简单的配置,可以在不显著影响应用性能的前提下,收集并展示一系列关键指标,帮助开发者和运维人员实时了解系统的运行状态。...
JavaMelody是一个开源的性能监控工具,主要用于监测Java Web应用程序的运行情况。版本1.43.0是这个工具的一个特定发行版,包含了对系统性能和应用健康状况的全面跟踪功能。下面将详细介绍JavaMelody及其1.43.0版本中...
JavaMelody是一款开源的Java应用性能监控工具,它允许开发者轻松地在Web应用程序中集成监控功能,无需修改代码。从标题“javamelody-javamelody-core-src-1.68.1.zip”可以看出,这包含的是JavaMelody核心组件1.68.1...
- **示例代码**:可能包含一些已经集成JavaMelody的示例项目,通过这些项目,你可以学习如何在自己的应用中添加JavaMelody监控。 - **jar文件**:这是JavaMelody的核心库,可能包含了不同版本的JavaMelody JAR,供...