`

网站建设中关于eclipse启动参数的优化

    博客分类:
  • Java
阅读更多

在网站建设中,经常用到eclipse,每次启动都是很费时间的,那么如何对它进行优化呢?

版本:Eclipse3.6

参数配置文件:eclipse.ini

结果:修改后启动速度直观上有比较明显的加快

注意:重点是后面红字部分的设置

首先建立评估体系,比如,我们需要建立一个网站http://www.hualai.net.cn,首先将workspace里所有的项目close掉,关闭eclipse。优化的用例就是启动eclipse,open一个项目,eclipse会自动build这个项目,保证没有感觉到明显的卡,也就是没有full GC。 

开始: 

eclipse.ini里加入打印gc情况的参数: 

 

-XX:+PrintGCTimeStamps
-XX:+PrintGCDetails
-verbose:gc
-Xloggc:gc.log 

这样eclipse在运行过程中会记录gc日志,显示详细的gc情况,并打印在gc.log中,通过分析这个日志寻找eclipse的性能瓶颈和优化方式。 

我最初的参数只是在原版基础上调了堆大小 

 

-Xms512m
-Xmx512m 

将堆初始化和最大值设为一样,消除堆大小根据当前堆使用情况而变化带来的影响。 

启动eclipse,发现gc.log里打出了很多full gc的日志 

4.226: [Full GC 4.226: [Tenured: 18470K->19304K(30544K), 0.1159544 secs] 25154K->19304K(44368K), [Perm : 24574K->24554K(24576K)], 0.1160431 secs] [Times: user=0.13 sys=0.00, real=0.13 secs] 

在启动的6秒多时间里共出现了8次full gc,所以启动慢,觉得启动时候挺卡的。从日志里可以看出来 FullGC主要是在回收tenured区和Perm区,其中Perm一直都是快满的状态,Perm : 24574K->24554K(24576K),Perm大小在不断调整,所以需要固定Perm区的大小,保证够用,eclipse.ini里加入 

-XX:PermSize=64m
-XX:MaxPermSize=64m 

再启动:发现没有full gc了只有数量比较多的minor gc,挑启动开始到启动完成的第一条和最后一条日志 

0.209: [GC 0.209: [DefNew: 4416K->511K(4928K), 0.0034707 secs] 4416K->614K(15872K), 0.0035239 secs] [Times: user=0.00 sys=0.00, real=0.00 secs]
….
6.383: [GC 6.383: [DefNew: 18880K->1985K(21184K), 0.0055311 secs] 46992K->30098K(68040K), 0.0055694 secs] 

这6秒中GC日志打了69次, 而内存回收率还是蛮高的 young区18880-1985=16895 jvm 46992-30098=16894 都快接近100%了,可以看出young区是由小到大在不断调整大小,所以不断GC,因此设一个初始值吧,据说设置heap的1/4比较好,那就是128M,所以eclipse.ini加入 

-Xmn128m 

再重启,发现GC日志就四条了,eclipse启动自然快了  

1.292: [GC 1.292: [DefNew: 104960K->10984K(118016K), 0.0334165 secs] 104960K->10984K(511232K), 0.0334603 secs] [Times: user=0.03 sys=0.00, real=0.03 secs]
2.182: [GC 2.182: [DefNew: 115944K->1852K(118016K), 0.0221714 secs] 115944K->11466K(511232K), 0.0222142 secs] [Times: user=0.00 sys=0.02, real=0.02 secs]
3.987: [GC 3.987: [DefNew: 106779K->12531K(118016K), 0.0378228 secs] 116393K->22145K(511232K), 0.0378692 secs] [Times: user=0.03 sys=0.00, real=0.03 secs]
5.377: [GC 5.377: [DefNew: 117491K->9403K(118016K), 0.0513728 secs] 127105K->31364K(511232K), 0.0514133 secs] 

但是,启动后open我的多个项目,这些项目互相依赖,eclipse自动build,感觉有点小卡,发现日志里多了4次full GC,所以就卡了… 

67.320: [Full GC (System) 67.320: [Tenured: 88847K->68809K(393216K), 0.2121213 secs] 117385K->68809K(511232K), [Perm : 41915K->41915K(65536K)], 0.2121747 secs] [Times: user=0.20 sys=0.00, real=0.20 secs]
103.759: [Full GC (System) 103.759: [Tenured: 81882K->66784K(393216K), 0.3287387 secs] 185350K->66784K(511232K), [Perm : 53464K->53414K(65536K)], 0.3287897 secs] [Times: user=0.33 sys=0.00, real=0.33 secs] 

这个时候Tenured区和Perm都还没到很接近最大值,但是为什么还有full GC呢,开始以为是JVM悲观认为Tenured区剩余空间不足以应对下一次minor GC 所以进行了full GC调整Tenured空间,索性直接增加了堆最大值到-Xmx728m(工作电脑的内存是3.5G),但重启后full gc还是有4次,而且有几次minor GC用的时间超过了0.1秒,这是因为增加了堆大小,导致GC用时也增加了,不能接受。所以还是改回-Xmx512m。 

再仔细观察日志,发现Full GC (System) 字样,这个意思是eclipse里调用了System.gc()手动触发了系统GC,好吧,哥已经给你分配足够空间了,你就省省吧,在eclipse.ini里加入: 

-XX:+DisableExplicitGC 

这样就差不多了,整个过程没有出现full gc,再编码2个小时,中间只出现了一次full gc,在open build某50W行+的代码的时候,eclipse还是卡了… 

最后又稍微调了一下各代的大小,得到目前的参数:  

-Xms512m
-Xmx512m
-XX:PermSize=96m
-XX:MaxPermSize=96m
-Xmn168m
-XX:+DisableExplicitGC 

另外没有去调GC策略,主要是觉得eclipse是客户端程序,默认的client单线程的GC策略应该是比较适合的,以后有时间再试试看吧。

 

1
8
分享到:
评论
3 楼 username2 2012-11-21  
感觉快了很多
2 楼 jueyue 2012-11-14  
确实有点快了
1 楼 小鱼不爱水 2012-08-23  
说半天也没说怎么解决!废话一大堆!

相关推荐

    apache-tomacat-9.0.0.M26(网站建设软件包之tomcat安装包)

    7. **性能优化**:可以通过调整Tomcat的配置参数,如增大最大线程数、优化连接器设置、启用NIO(非阻塞I/O)模式、开启GZIP压缩等方式提升其性能。 8. **安全性**:Tomcat的安全配置包括设置SSL/TLS支持,配置 ...

    cms 基于java

    1. **灵活性高**:用户可以自由定义网站结构,调整布局,满足不同类型的网站建设需求。 2. **扩展性强**:不仅提供了完整的源代码,还允许开发者根据实际需求进行二次开发。 3. **模块化设计**:系统采用了模块化的...

    JEECMS

    总结,JEECMS是一款强大且灵活的Java EE内容管理系统,适合企业级的网站建设和管理。其丰富的功能、良好的扩展性以及广泛的社区支持,使其在同类产品中具有较高的竞争力。通过熟练掌握JEECMS,开发者可以快速搭建和...

    基于Java的Lerx开源网站内容管理系统(CMS.ext).zip

    综上所述,Lerx CMS是一个功能全面、技术先进的Java CMS解决方案,适用于各种规模的网站建设和管理,无论是个人博客还是企业级门户,都能从中受益。通过了解其核心技术、特点和开发流程,开发者可以更好地利用Lerx ...

    liferay6开发简介

    在 Liferay IDE 中,你可以通过向导选择所需的插件类型,按照步骤配置参数,然后IDE会自动生成相应的项目结构和基础代码。 ### 3. 开发流程 开发 Liferay 插件通常涉及以下步骤: 1. **需求分析**:明确功能需求...

    百度去BMR解决方案,百度云平台

    - **网站日志处理**:通过分析网站的日志文件,可以获取用户行为模式、流量统计等信息,帮助企业优化用户体验和提高运营效率。 - **数据仓库建设**:构建企业级的数据仓库,整合来自不同源的数据,支持复杂的查询和...

Global site tag (gtag.js) - Google Analytics