java – Spring AOP启动时间慢
我们使用带有@AspectJ样式注释的Spring(3.0.5)AOP和< aop:aspectj-autoproxy /> 我做了一些分析,发现大部分时间是在Spring容器初始化期间花费的,更具体地说是org.springframework.beans.factory.support.DefaultSingletonBeanRegistry.getSingleton(String,ObjectFactory) – 大约需要35秒. 我的目标是让应用程序在5-10秒内启动,而不是现在的约45秒,所以任何提示都会非常感激. 最佳答案
我有同样的问题,事实证明Spring AOP自动代理在启动时花了很多时间用bcel加载类(没有缓存,所以一次又一次地加载像java.lang.Object这样的类……)哪些建议适用.
通过编写更细粒度的Point cut(在内部使用,例如@within)可以稍微改进一下但是如果所有的切入点都是用@annotation编写的,我找到了一个更好的解决方案. 1)使用以下命令停用自动代理:spring.aop.auto = false 2)编写AnnotationAwareAspectJAutoProxyCreator的自定义子类,根据您自己的标准过滤要装饰的bean,例如,这个基于包和注释:
在我的情况下,启动时间从60秒降至15秒. 我希望它会帮助某人和北极熊 (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |