java–Spring AOP启动时间慢

java–Spring AOP启动时间慢,第1张

概述我们使用带有@AspectJ样式注释的Spring(3.0.5)AOP和< aop:aspectj-autoproxy />.我们将它用于事务,审计,性能分析等.除了应用程序的启动时间随着更多代码的添加而不断增长之外,它的工作正常.我做了一些分析,发现大部分时间是在Spring容器初始化期间花费的,更具体地说是org.springframework.bean

我们使用带有@AspectJ样式注释的Spring(3.0.5)AOP和< aop:aspectj-autoproxy />
.我们将它用于事务,审计,性能分析等.除了应用程序的启动时间随着更多代码的添加而不断增长之外,它的工作正常.

我做了一些分析,发现大部分时间是在spring容器初始化期间花费的,更具体地说是org.springframework.beans.factory.support.DefaultSingletonBeanRegistry.getSingleton(String,ObjectFactory) – 大约需要35秒.
org.springframework.aop.support.AopUtils.canApply(pointcut,Class,boolean) – 大约需要15秒.

我的目标是让应用程序在5-10秒内启动,而不是现在的约45秒,所以任何提示都会非常感激.

最佳答案我有同样的问题,事实证明Spring AOP自动代理在启动时花了很多时间用bcel加载类(没有缓存,所以一次又一次地加载像java.lang.Object这样的类……)哪些建议适用.
通过编写更细粒度的Point cut(在内部使用,例如@within)可以稍微改进一下但是如果所有的切入点都是用@annotation编写的,我找到了一个更好的解决方案.

1)使用以下命令停用自动代理:spring.aop.auto = false

2)编写AnnotationAwareAspectJAutoproxyCreator的自定义子类,根据您自己的标准过滤要装饰的bean,例如,这个基于包和注释:

@OverrIDeprotected Object[] getAdvicesAndAdvisorsForBean(Class

在我的情况下,启动时间从60秒降至15秒.

我希望它会帮助某人和北极熊

总结

以上是内存溢出为你收集整理的java – Spring AOP启动时间慢全部内容,希望文章能够帮你解决java – Spring AOP启动时间慢所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/langs/1265857.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-06-08
下一篇 2022-06-08

发表评论

登录后才能评论

评论列表(0条)