`
tomcat_oracle
  • 浏览: 318031 次
社区版块
存档分类
最新评论

加速Java应用调试Spring启动速度

    博客分类:
  • Java
阅读更多

在调试spring应用时,动辄几十秒,甚至有的应用上分钟的启动速度,会让整个调试速度慢下来了。等待时间让人抓狂。不知道大家是如何加速spring应用调试速度的,在此分享下我的一次加速过程。欢迎补充指正。

环境

配置:

  1. thinkpad t410 
  2. 内存:4G内存 
  3. CPU:Intel P8700 双核2.53GHZ 
  4. 系统:WIN XP 
  5. 开发工具:Intellij IDEA 12.0.4 
  6. Maven + spring3.2.3 + hibernate4.2.2+Spring data jpa 1.3.1 

未优化前spring容器启动速度:

16890毫秒 =(14609毫秒(ContextLoaderListener加载的)+2281毫秒(Springmvc加载的)

优化后spring容器启动速度:

7797毫秒 =(6563毫秒(ContextLoaderListener加载的)+1234毫秒(Springmvc加载的)

速度提升了一半多,而且以后在调试阶段,大部分就停留在这个时间左右。

注意:此处只是spring容器启动速度,不包括服务器启动时的速度。因为我的系统好久没清理了,否则可能速度会更快。

加速Spring

1、扫描注解Bean

写比较精确的扫描路径,如扫描@Service和@Repository:

  1. <context:component-scan base-package="com.sishuok.es.**.repository,com.sishuok.es.**.service,com.sishuok.es.**.extra"> 

这样写,比直接写com.sishuok.es速度要快很多,因为这样扫描的class会很少。

还有,如springmvc 扫描:

  1. <context:component-scan base-package="com.sishuok.es.**.web.controller" use-default-filters="false"> 

此处只扫描项目的web.controller包,这样扫描的class也很少。

还有如事务的扫描:

  1. execution(* com.sishuok.es..service..*+.*(..) 

还有如使用spring data jpa时也是这样:

  1. <jpa:repositories 
  2.             base-package="com.sishuok.es.**.repository" 

这里需要大家有良好的分包,否则无法优化。

2、延迟加载你的bean

常见的方式是在配置文件中在<beans>上加:

  1. default-lazy-init="true" 

2.1、这种方式只对xml声明的bean有效;

2.2、注解扫描的bean无效,如@Service,需要使用@Lazy指定,但这样太麻烦,需要一个一个的配置;

2.3、还有就是如果你使用springmvc,lazy-init几乎没啥用,因为springmvc容器在启动时会通过 DefaultAnnotationHandlerMapping查找相关的带有@RequestMapping的bean并注册请求映射;所以相关的如 Service/Repository也级联非lazy-init;

因此我写了个工具:SpeedUpSpringProcessor,其作用是:lazy-init所有bean,包括注解的bean;对于【2.3】后续介绍解决方案;具体配置请参考最后。

3、移除调试阶段不相干的bean

有些bean在调试阶段我们并不需要,如我们在测试用户模块时,可能不需要测试权限模块;此时我们可以把不相干的bean移除掉;具体配置请参考最后。

这样的话,可以考虑如把@Controller的bean移除,这样的话如Service/Repository就可以lazy-init了。

常见的可以移除的如:

  • 任务调度器(quartz)、AOP相关等等;
  • 此处需要合理的分包,否则无法应用或应用困难。

4、删除无用属性

如在测试shiro时,可能不需要remember的功能,此时可以把属性移除/禁用(即将值设置为false);具体配置请参考最后。

5、替换正式机数据源为最快的数据源

如此处我把DruidDataSource数据源直接替换为org.springframework.jdbc.datasource.DriverManagerDataSource,这个速度最快;

6、替换jackson为fastjson

此处测试了下jackson速度比fastjson慢许多的。支持国产。

7、项目分模块开发 

如果项目模块比较多,可以考虑放弃注解,而使用xml配置方式+约定。因为实际做项目时可能把配置分到多个配置文件,此时我尝试了下合并到一个,几乎没啥速度提升,所以还是分开存好。

到此spring容器启动速度算是比较快了,不知道大家还有没有好的策略。欢迎指点。

加速Hibernate/JPA

此处以org.springframework.orm.jpa.LocalContainerEntityManagerFactoryBean为例。

1、 精确化packagesToScan

和之前的spring一样,写比较精确的实体扫描路径

  1. <property name="packagesToScan" value="com.sishuok.es.**.entity"/> 

2、generateDdl=false 禁用掉

没必要每次都生成ddl

3、 禁用JSR-303验证

默认情况下是AUTO,会根据classpath下是否有jsr-303实现来自动注册;

  1. <!-- 使用自定义的validator进行jsr303验证 --> 
  2. <entry key="javax.persistence.validation.factory" value-ref="validator"/> 
  3. <!-- jsr303验证模式 因为其要么验证 要么不验证 不能按照规则走 所以此处禁用 --> 
  4. <!-- #http://docs.jboss.org/hibernate/entitymanager/3.6/reference/en/html/configuration.html --> 
  5. <entry key="javax.persistence.validation.mode" value="NONE"/> 

此处validator 直接引用我们项目中定义的,而不是让hibernate再去new一个。而且也不推荐在这验证,具体为什么,请参考我的《我是这样认识注解和XML的》。

4、如果你的项目都是注解,此时就没必要扫描hbm了,禁用掉

  1. <entry key="hibernate.archive.autodetection" value="class"/> 

5、如果你不使用NamedQuery,禁用掉

  1. <entry key="hibernate.query.startup_check" value="false"/> 

6、在调试阶段禁用掉二级缓存

通过如上手段,我的spring容器启动速度提升了一半多。大家还有好的优化策略吗?如果有欢迎补充。具体配置请参考最后。

之前提到的SpeedUpSpringProcessor配置

  1. <!-- 优化spring启动 通过移除bean定义 和 lazy init 实现 --> 
  2. <bean class="com.sishuok.es.common.spring.SpeedUpSpringProcessor"> 
  3.     <!-- 需要从bean定义中移除的bean的名字 --> 
  4.     <property name="removedBeanNames"> 
  5.         <list> 
  6.             <!-- spring-config-quartz.xml --> 
  7.             <value>scheduler</value> 
  8.             <value>autoClearDeletedRelationTrigger</value> 
  9.             <value>autoClearExpiredOrDeletedmMessageTrigger</value> 
  10.             <value>autoClearDeletedRelationJob</value> 
  11.             <value>autoClearExpiredOrDeletedmMessageJob</value> 
  12.   
  13.             <!-- spring-config-shiro.xml --> 
  14.             <value>rememberMeCookie</value> 
  15.             <value>rememberMeManager</value> 
  16.             <value>shiroCacheManager</value> 
  17.             <value>sessionValidationScheduler</value> 
  18.             <value>sessionValidationScheduler</value> 
  19.             <!-- spring-mvc.xml --> 
  20.             <value>multipartResolver</value> 
  21.   
  22.             <!-- spring-config-monitor.xml --> 
  23.             <value>druidStatInterceptor</value> 
  24.             <value>druidAdvisor</value> 
  25.         </list> 
  26.     </property> 
  27.     <!-- 需要从bean定义中移除的bean的属性 --> 
  28.     <!--替换掉的属性值 see removedBeanProperties 只支持简单属性--> 
  29.     <property name="removeOrReplaceBeanProperties"> 
  30.         <list> 
  31.             <!-- spring-config-shiro.xml --> 
  32.             <value>sessionManager#cacheManager</value> 
  33.             <value>sessionManager#cacheManager</value> 
  34.             <value>sessionManager#sessionValidationScheduler</value> 
  35.             <value>securityManager#rememberMeManager</value> 
  36.   
  37.             <!-- spring-config.xml --> 
  38.             <value>entityManagerFactory#jpaPropertyMap#hibernate.default_batch_fetch_size"</value> 
  39.             <value>entityManagerFactory#jpaPropertyMap#hibernate.max_fetch_depth"</value> 
  40.             <value>entityManagerFactory#jpaPropertyMap#hibernate.generate_statistics</value> 
  41.             <value>entityManagerFactory#jpaPropertyMap#hibernate.bytecode.use_reflection_optimizer</value> 
  42.             <value>entityManagerFactory#jpaPropertyMap#hibernate.cache.use_second_level_cache=false</value> 
  43.             <value>entityManagerFactory#jpaPropertyMap#hibernate.cache.use_query_cache</value> 
  44.             <value>entityManagerFactory#jpaPropertyMap#hibernate.cache.region.factory_class</value> 
  45.             <value>entityManagerFactory#jpaPropertyMap#hibernate.cache.use_structured_entries</value> 
  46.             <value>entityManagerFactory#jpaPropertyMap#net.sf.ehcache.configurationResourceName</value> 
  47.         </list> 
  48.     </property> 
  49.   
  50.     <!-- 需要从bean定义中移除指定的类类型 正则表达式--> 
  51.     <property name="removedClassPatterns"> 
  52.         <list> 
  53.              <value>com\.sishuok\.es\.showcase.*</value> 
  54.              <value>com\.sishuok\.es\.monitor.*</value> 
  55.              <value>com\.sishuok\.es\.extra\.aop.*</value> 
  56.              <value>com\.sishuok\.es\.extra\.quartz.*</value> 
  57.              <value>com\.sishuok\.es\.conf.*</value> 
  58.              <!--<value>com\.sishuok\.es\.personal.*\.web\.controller.*</value>--> 
  59.              <!--<value>com\.sishuok\.es\.sys.*\.web\.controller.*</value>--> 
  60.         </list> 
  61.     </property> 
  62.   
  63.     <!-- 指定非延迟加载的bean--> 
  64.     <property name="noneLazyBeanNames"> 
  65.         <list> 
  66.             <value>domainClassConverter</value> 
  67.         </list> 
  68.     </property> 
  69. </bean> 
  1. 默认所有bean lazy-init;
  2. removedClassPatterns:正则表达式,即可以移除的bean的class路径模式,bean class匹配该模式的将移除;此处需要良好的分包,否则不好应用;
  3. removedBeanNames:即在调试期间可以移除的bean;
  4. removeOrReplaceBeanProperties:调试期间可以删除/替换掉的bean属性;如移除shiro的sessionManager的cacheManager;如禁用hibernate二级缓存:entityManagerFactory#jpaPropertyMap#hibernate.cache.use_second_level_cache=false
  5. noneLazyBeanNames:有些bean不能lazy-init;排除掉。

具体实现请参考:

可以直接下载使用。

SpeedUpSpringProcessor:

https://github.com/zhangkaitao/es/blob/master/common/src/main/java/com/sishuok/es/common/spring/SpeedUpSpringProcessor.java

spring-speed-up.xml:

https://github.com/zhangkaitao/es/blob/master/web/src/main/resources/spring-speed-up.xml

其他提到的配置文件都在:

https://github.com/zhangkaitao/es/tree/master/web/src/main/resources

开启/关闭:

此处我使用了spring的profile:

  1. <beans profile="development" > 

即只有当System.getProperties中有spring.profiles.active=developement才执行调试模式,所以如果没有该配置还是走的正常流程,对系统没有影响,所以此处大家可以使用:

1、jetty内嵌执行时设置该属性

  1. <plugin> 
  2.     <groupId>org.mortbay.jetty</groupId> 
  3.     <artifactId>jetty-maven-plugin</artifactId> 
  4.     <version>${jetty.version}</version> 
  5.     <configuration> 
  6.         ---省略 
  7.         <!-- spring profile  --> 
  8.         <systemProperties> 
  9.             <systemProperty> 
  10.                 <name>spring.profiles.active</name> 
  11.                 <value>development</value> 
  12.             </systemProperty> 
  13.         </systemProperties> 
  14.     </configuration> 
  15. </plugin> 

 

2、写多个bat文件分别执行不同的情况。

15
6
分享到:
评论
8 楼 guduxing890 2013-11-07  
不厚道。.....
7 楼 inotgaoshou 2013-11-06  
抄袭也能上首页~楼主真没RP,抄袭开涛老师的文章居然不注明~
6 楼 无处不在的风 2013-11-05  
张开涛是我的老师 楼主请速速删除
5 楼 lvwenwen 2013-11-05  
在iteye上转载张开涛的文章?
4 楼 sgq0085 2013-11-05  
在iteye上转载张开涛的文章,还不注明? 楼主还有人品了么?
3 楼 zhoujiangzi 2013-11-05  
好像在哪里看过~蛋不是同一个作者
2 楼 无处不在的风 2013-11-05  
请不要抄袭 请楼主尊重别人的成果 删掉吧
1 楼 ansjsun 2013-11-05  
针对这种问题。最好的办法就是不用spring

相关推荐

    Java_Springstartupanalyzer生成一个交互式的spring应用程序启动报告,让您了解是什么因素导.zip

    Java Spring Startup Analyzer是一款强大的工具,专门用于分析Spring应用程序的启动过程,帮助开发者深入理解应用程序启动时间的消耗,找出性能瓶颈,从而优化应用的启动速度。这个工具为开发者提供了一个交互式的...

    LEARNING SPRING BOOT 3.0 - THIRD EDITION

    性能优化方面,Spring Boot 3.0可能会进一步改善其自动配置机制,提高应用启动速度和运行效率。对于微服务架构的支持也会得到增强,这对于构建大型分布式系统来说至关重要。同时,安全性一直是Spring Boot关注的重点...

    springloaded

    2. **设置JVM参数**:在启动Java应用时,需要添加特定的JVM参数来指定SpringLoaded的使用。常见的设置包括`-javaagent`参数,例如`-javaagent:path/to/springloaded-1.2.5.RELEASE.jar`,确保指定了正确的jar路径。 ...

    基于Spring Boot的律师事务所案件管理系统的设计与开发-论文-java-基于Spring Boot的律师事务所案件管理

    - **启动速度快**:由于其简洁的配置机制,Spring Boot应用的启动速度非常快。 - **易于监控**:提供了Actuator模块,可以通过HTTP接口监控应用的状态。 ##### 2. 数据库设计与实现 - **ER模型**:在系统设计初期...

    VsCode搭建Spring Boot项目并进行创建、运行、调试

    "VsCode搭建Spring Boot项目并进行创建...同时,本资源还介绍了相关的知识点,如VsCode安装扩展、配置Maven、VsCode中使用Maven、VsCode中使用Spring Boot、VsCode中进行调试、使用阿里云的镜像加速Maven更新包速度等。

    spring tool suite 3-9-5

    这些工具能够帮助开发者更高效地创建、管理和调试Spring应用程序。 2. **Spring Boot**:Spring Boot简化了Spring应用程序的初始设置和配置,通过内置的依赖和默认配置,使得开发者可以快速启动项目。在STS 3.9.5中...

    spring-framework-4.0.0.RELEASE 完整包

    1. **模块化设计**:Spring Framework 4.0.0.RELEASE采用了更加模块化的结构,允许开发者根据项目需求选择必要的组件,降低了应用的体积,提高了启动速度。主要模块包括Core Container(核心容器)、Data Access/...

    新闻网站开发项目,java语言开发

    新闻网站开发项目通常涉及到多个技术层面,本项目采用Java语言,结合Spring Boot、Spring MVC、MyBatis和Redis等框架和技术来构建一个高效、可扩展的新闻资讯平台。以下是这些技术的相关知识点及其在项目中的应用。 ...

    spring-boot-2.0.0.M1

    《Spring Boot 2.0.0.M1:新一代Spring Java应用开发框架的里程碑》 Spring Boot,作为Java领域内的一款微框架,自诞生以来就以其便捷的启动方式、极简的配置以及强大的功能赢得了广大开发者的心。而Spring Boot ...

    spring-tool-suite-3.9.8.RELEASE-e4.11.0-win32-x86_64.zip

    4. **Spring Boot支持**:集成对Spring Boot的全面支持,包括启动器管理、应用运行、Actuator监控等,方便开发和调试Spring Boot应用。 5. **Spring Boot DevTools**:通过集成Spring Boot DevTools,开发者可以...

    远程调试启动脚本.zip

    在启动过程中,除了加载SpringBoot应用外,可能还会包含远程调试所需的参数,如上述的JDWP参数。这样,开发者就能在本地IDE中通过这些端口连接到远程服务器进行调试。 4. **配置远程调试**: 在IDE中,例如...

    Spring的jar包解析

    根据项目的需求,可以选择引入特定的jar包,而不是全部引入spring.jar,这样可以避免不必要的类加载,提升应用启动速度。此外,通过深入研究源代码,开发者能够更好地理解和定制Spring的功能,从而提升软件开发的...

    Spring Boot快速搭建和部署应用程序

    - **定义**:Spring Boot是一种基于Java的开发框架,旨在简化并加速应用程序的构建过程。 - **背景**:由Spring团队开发,构建在Spring框架之上,提供了一种快速搭建和部署应用程序的方式。 - **核心优势**: - **...

    spring-tools-suite3.9

    在STS中,开发人员可以享受到智能代码提示和自动完成功能,这些功能基于Spring的元数据,能够帮助快速编写正确的Spring配置和Java代码,减少错误并提高开发速度。 6. **调试与测试工具**: STS集成了强大的调试和...

    Spring 3.1 jar包

    最后,Spring 3.1 进行了性能优化,降低了内存占用,提高了启动速度,并且提供了更完善的监控和诊断工具,便于开发者调试和优化应用程序。 综上所述,Spring 3.1 jar包包含了Spring框架在多个层面的改进和新特性,...

    spring3.2.0.RELEASE版jar包【整合版,包含所有的主要jar包】-正式版下载

    5. **性能提升**:通过对内部组件的优化,Spring 3.2在性能方面有了显著提高,尤其是在启动速度和内存消耗上。 #### 三、Spring 3.2.0.RELEASE整合包内容 - **核心容器**:包含了Spring的核心功能,如BeanFactory...

    Spring-3.0.6的src包

    此外,Spring 3.0.6还对性能进行了优化,提升了容器启动速度,并且改进了与其他开源库的兼容性。 通过研究Spring-3.0.6的源代码,开发者可以深入理解Spring的工作原理,学习如何利用IoC和AOP设计模式,以及如何结合...

    SpringToolSuite for mac.zip

    4. **Spring Boot支持**:STS集成了Spring Boot DevTools,提供实时应用重启和热部署功能,大大加快了开发迭代速度。 5. **测试工具**:内置的JUnit和Mockito支持使单元测试和集成测试变得更加简单,同时提供了测试...

    sts-4.10.0.RELEASE(开发工具SpringToolSuite4)

    在性能优化上,STS 4.10.0.RELEASE进行了多项改进,包括更快的启动速度、更好的内存管理以及更流畅的UI响应。这些改进旨在减少开发过程中的等待时间,提高工作效率。 总的来说,SpringToolSuite4 4.10.0.RELEASE是...

Global site tag (gtag.js) - Google Analytics