springboot项目启动慢的问题排查方式

网友投稿 843 2022-09-30


springboot项目启动慢的问题排查方式

目录springboot项目启动慢的问题排查1.最开始查看的启动日志,是在输出:2. 启动项目,打印日志级http://别改为debug,查看更详细信息如何优化SpringBoot的项目的启动速度实际上它是下面三个注解的组合可以用@SpringBootApplication注解下面的属性

springboot项目启动慢的问题排查

springboot项目,随着时间的推移,启动耗时逐步增加,从几分钟慢慢的达到30多分钟,有点恐怖!

项目中用到技术:hibernate、redis、kafka、线程池等,启动慢的环境使用的是mysql数据库!

1.最开始查看的启动日志,是在输出:

org.hibernate.id.UUIDHexGenerator : HHH000409: Using org.hibernate.id.UUIDHexGenerator which does not generate IETF RFC 4122 compliant UUID values; consider using org.hibernate.id.UUIDGenerator instead

后停滞,等相当长时间后继续输出:

o.s.s.concurrent.ThreadPoolTaskExecutor : Initializing ExecutorService 'taskExecutor'

怀疑是创建kafka、线程池等导致耗时,通过去掉相关对象创建,耗时仍无改观!

2. 启动项目,打印日志级别改为debug,查看更详细信息

发现:大量的alter table 增加外键!奇怪,不是第一次启动项目,mysql库中的表早已创建好,为什么每次都要重复alter?

查看mysql相关表发现无外键,表引擎为MyISAM!此引擎不支持http://外键!

在使用hibernate自动创建表时,mysql中建表使用的MyISAM引擎,查看配置:

dialect:应使用org.hibernate.dialect.MySQL5InnoDBDialect

这就解释了:为什么orcle环境下没有此问题,而mysql就有,其随着时间的推移,表中数据逐渐增加,在启动时alter table耗时严重!

如何优化SpringBoot的项目的启动速度

日常开发SpringBoot项目启动类都用@SpringBootApplication

实际上它是下面三个注解的组合

@EnableAutoConfigurationbkUBzQs: enable Spring Boot's auto-configuration mechanism

@ComponentScan: enable @Component scan on thttp://he package where the application is located (see the best practices)

@Configuration: allow to register extra beans in the context or import additional configuration classes

启动慢往往跟@ComponentScan和@EnableAutoConfiguration加载的内容太多有关,一种方法是不用这两个注解,通过@import注解精确指定要加载扫描的类,但要加载的类多时又很麻烦,

可以用@SpringBootApplication注解下面的属性

exclude: Exclude the list of classes from the auto configuration.

excludeNames: Exclude the list of fully qualified class names from the auto configuration. This parameter added since spring boot 1.3.0.

scanBasePackageClasses: Provide the list of classes that has to be applied for the @ComponentScan.

scanBasePackages Provide the list of packages that has to be applied for the @ComponentScan. This parameter added since spring boot 1.3.0.

另外,如果SpringBoot项目启动很慢,可能意味着你要重新拆分微服务。


版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:网站快照被篡改劫持的手段分析
下一篇:如何防止网站快照被劫持收录攻击(网站百度快照劫持问题)
相关文章

 发表评论

暂时没有评论,来抢沙发吧~