欢迎来到天天文库
浏览记录
ID:53000838
大小:804.35 KB
页数:7页
时间:2020-04-10
《IntelliJ IDEA 内存优化最佳实践方法.pdf》由会员上传分享,免费在线阅读,更多相关内容在行业资料-天天文库。
1、IntelliJIDEA内存优化最佳实践【编者按】本文作者在和同事的一次讨论中发现,对IntelliJIDEA内存采用不同的设置方案,会对IDE的速度和响应能力产生不同的影响。Don’tbeaScroogeandgiveyourIDEsomemorememory不要做守财奴,给IDE多留点内存吧。昨天,大家就是否自定义IntelliJIDEA的内存设置进行了讨论,有些人选择默认设置,有些人会对默认的设置进行简单的变更,还有一些开发者会基于他们的需求进行全面复杂的设置。笔者目前的工作是处理几个微服务项目和一个老项目,而客户的核心业务需求非常
2、大。对IntelliJIDEA内存进行简单设置以后,笔者明显感受到了该IDE在速度和响应方面的改善。但当时笔者并未进行具体的测量,所以这只是主观感受而已。不过,参与讨论的一位开发者给笔者发了一份他的设置,虽然是针对同个项目,该设置却极其复杂。笔者对自己的设置并无不满,但非常好奇,这些完全不同的设置对比JetBrains提供的默认设置,会有怎样的不同。目标笔者的计划是,在一个接近日常开发项目的场景下(加载一个大项目、加载2、3个微服务、gitpull后刷新大项目),测试各个设置带来的效果,并选出内存消耗和速度都达到最优时的最佳设置。测试机器
3、和项目笔记本电脑:MacBookProRetina,2.3GHzIntelCorei7,16GB1600MhzDDR3,SSDDisc,OSXYosemite项目大项目——Monolith,70万行代码(Java8和Groovy),303个Gradle模块两个微服务——约有10000——20000行代码(Java8和Groovy)的小项目,各有一个Gradle模块测试场景1.在Idea中关闭所有项目2.基于测试文件idea.vmoptions进行设置3.重启电脑4.启动后关闭所有不相关的项目(communicators等等)5.打开Ide
4、a(测试时间)6.打开大项目(测试时间)7.检查jstat-gcutil8.打开两个微服务项目(测试时间)第1页共7页9.检查jstat-gcutil10.返回大项目然后点击“刷新Gradle项目”按钮(测试时间)11.检查jstat-gcutiljstat-gcutiljstat是JDK自带的工具,主要利用JVM内建的指令对Java应用程序的资源和性能进行实时的命令行监控,还包括对Heapsize和垃圾回收状况的监控。它有许多选项来收集各种数据(完整的文档),但这里只会用到:-gcutil:-gcutil-Summaryofgarbag
5、ecollectionstatistics.S0:Survivorspace0utilizationasapercentageofthespace'scurrentcapacity.S1:Survivorspace1utilizationasapercentageofthespace'scurrentcapacity.E:Edenspaceutilizationasapercentageofthespace'scurrentcapacity.O:Oldspaceutilizationasapercentageofthespace'scur
6、rentcapacity.M:Metaspaceutilizationasapercentageofthespace'scurrentcapacity.CCS:Compressedclassspaceutilizationasapercentage.YGC:NumberofyounggenerationGCevents.YGCT:Younggenerationgarbagecollectiontime.FGC:NumberoffullGCevents.FGCT:Fullgarbagecollectiontime.GCT:Totalgarb
7、agecollectiontime.这个命令的输出结果如下:S0S1EOMCCSYGCYGCTFGCFGCTGCT89.700.0081.2674.2795.6891.76402.444140.7153.159在本文中,最重要的参数是GC事件(YGC和FGC)次数和收集时间(YGCT和FGCT)。测试设置笔者设置了四种不同的设置,为了好记,给它们起了不同的名字。默认(灰色标识)JetBrains提供的默认设置:-Xms128m-Xmx750m-XX:MaxPermSize=350m-XX:ReservedCodeCacheSize=240
8、m-XX:+UseCompressedOopsBig(大)(红色标识)给Xmx配4096MB,ReservedCodeCacheSize设置1024MB,这已经是相当多的内存了:-Xms102
此文档下载收益归作者所有