idea debug 启动慢出现假死

断点设置不合理引发应用启动慢
问题
java idea应用启动很慢|非常慢|超级慢的问题排查!

解决
关于应用启动超慢这个问题,其实两年前就已经遇到过,https://blog.csdn.net/li396864285/article/details/52944814 当时的解决方案时,把所有断点Mute breakPoints去掉,然后启动就正常了。

排查
如今,再次遇到这个问题,不能再忍了,该问题必须查明详细的原因,反复debug启动多次都是一样的结果,超慢,阻塞在连接zk的地方就不动了,debug窗口出现如下信息:Method breakpoints may dramatically slow down debugging。

分析
果然,断点打在了不该打的地方,当程序启动一直阻塞假死的同时,电脑也卡得不行。于是使用top 命令观察性能和资源消耗情况,启动的java进程一直占用cpu接近100%。

总结
反复试验过后,得出猜测的结论:当我们把断点打在方法上,会导致jvm初始化装载该类的时候,idea加载此时的debug信息(包括线程上下文,变量快照等),从而出现异常情况,一直循环加载debug信息无果,最终出现程序假死,阻塞启动。

断点无论是加在类的方法,还是接口的方法上,都会出现上面的启动慢,程序假死的情况。

另附
附图说明如下:

 

 

 



 
版权声明:本文为博主原创文章,转载请附上博文链接!

posted on 2019-04-26 09:35  奔跑吧人生  阅读(601)  评论(0编辑  收藏  举报

导航