背景
项目最近做了大的改动,添加了大量配置,Spring Boot项目启动时间从原来的100秒变成了400秒以上。从大量无效日志中一时难以看出瓶颈所在。首先需要一款性能分析软件,发现Intel® VTune™ Profiler对项目性能影响甚小。
性能分析
VTune是 Intel 提供的一个强大的应用程序性能分析软件,如何使用只需要看这两篇官方教程。(下载需要注册intel账号)
《在windows上面启动》
《分析Java程序》
为了能够在VTune分析Java项目,首先创建一个启动脚本启动项目,然后在VTune创建一个性能分析项目开启性能监控。
start.bat脚本如下,很简单。
java -jar myboot.jar
项目启动后结束性能监控,VTune会自动分析监控结果,在Bottom-up Tab页可以看到哪些方法花费了大量CPU时间。
其中Spring的一个matches方法就占用了50秒。
org.springframework.boot