热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

JavaPerformanceTuning笔记

pdf在这里:http:mfinocchiaro.files.wordpress.com200807java-virtual-machine-neutral.pdf以及关于gc的

pdf在这里: http://mfinocchiaro.files.wordpress.com/2008/07/java-virtual-machine-neutral.pdf

其实这篇文章比较早,主要是针对当时的java 4,java 5,只是一个基本参考.

HotSpot VM Heap Layout
Young Generation: Eden Spce | Suvivor Space(From Space & To Space)
Old Generation: Tenured Space
Permanent Generation: Permanent Space
Young Generatio大小使用-Xmn选项指定,而Suvivor Space大小则用-XX:SurviorRatio指定,注意From Space和To Space大小相同,该选项指定的是Eden Space大小/From(or to) Space大小.
如果Young generation满了就调用Scavenge GC(即Minor GC),Eden Space中未被回收的对象进入From,而每次minor GC结束之后,from和to指针对换.如果一个对象在几次minor gc之后仍然幸存则从to space提升到old generation.
old generation大小使用-Xms(初始大小)和-Xmx(最大大小)指定,32位系统在不同架构下Xmx有大小限制.指定-d64后使用64位jvm,性能下降5%-20%.
Permanent Generation用于保留class file.主要是编译的class和jsp页面.如果该空间满了会调用Full GC,使用-XX:PermSize和-XX:MaxPermSize指定.
RMI协议或者java用户可以显式调用System.gc()调用Full GC,可以使用-XX:+DisableExplicitGC选项禁止显式调用.
Default Garbage Collection Algorithms
分别是Minor GC和Full GC.
Java1.4后Minor GC可以使用多线程(ParallelGCThreads),但如果多于CPU核心数仍会是瓶颈.
Full GC在回收时会对heap中对象扫描两次,如果第二次扫描时仍未完成回收,它们将被加入下次Full GC的回收队列.因此FullGC非常耗时,jvm tuning就是要减少Full GC并确保不发生OOME(Out Of Memory Error).

Alternative Garbage Collectors

Parallel Copy GC:用在Eden Space,使用选项-XX:+UseParNewGC和-XX:ParallelGCThreads指定.

Concurrent Mark-and-Sweep:基于mark-and-sweep算法进行回收,使用选项-xx:UseConMarkSweepGC指定.

-XX:+UseCMSCompactAtFullCollection  default
true 对老年代进行压缩,可能影响性能,但是可以消除碎片。


-XX:CMSFullGCsBeforeCompaction=n
CMS进行n次full gc后进行一次压缩。
如果n=0,每次full gc后都会进行碎片压缩

CMS需要更多的内存,一方面是碎片问题,另一方面是对老年代回收不是在老年代满的时候,而是当老年代内存达到一定比例。

-XX:CMSIntiatingOccupancyFractio=n 当老年代内存使用达到n%,开始会后
jdk5 默认是68% 


Monitoring GC Duration & Frequency

通过ps或jps命令找到pid后,使用jstat -gc命令查看,如我在服务器上看到的Home server是这样的:

 S0C    S1C    S0U    S1U      EC       EU        OC         OU       PC     PU    YGC     YGCT    FGC    FGCT     GCT   
4032.0 1152.0  0.0   1127.2 546048.0 228879.1 4233408.0  3880211.0  70848.0 70531.1 134887 3342.336  216  1091.770 4434.107

启动了12天,花1小时多一点进行gc,总数上还可以.


Tim Yang blog上的文章比较简洁:http://timyang.net/tag/gc/

Java Performance Tuning笔记,布布扣,bubuko.com


推荐阅读
  • 2023 ARM嵌入式系统全国技术巡讲旨在分享ARM公司在半导体知识产权(IP)领域的最新进展。作为全球领先的IP提供商,ARM在嵌入式处理器市场占据主导地位,其产品广泛应用于90%以上的嵌入式设备中。此次巡讲将邀请来自ARM、飞思卡尔以及华清远见教育集团的行业专家,共同探讨当前嵌入式系统的前沿技术和应用。 ... [详细]
  • 本文总结了2018年的关键成就,包括职业变动、购车、考取驾照等重要事件,并分享了读书、工作、家庭和朋友方面的感悟。同时,展望2019年,制定了健康、软实力提升和技术学习的具体目标。 ... [详细]
  • 深入理解Cookie与Session会话管理
    本文详细介绍了如何通过HTTP响应和请求处理浏览器的Cookie信息,以及如何创建、设置和管理Cookie。同时探讨了会话跟踪技术中的Session机制,解释其原理及应用场景。 ... [详细]
  • 本文介绍了一款用于自动化部署 Linux 服务的 Bash 脚本。该脚本不仅涵盖了基本的文件复制和目录创建,还处理了系统服务的配置和启动,确保在多种 Linux 发行版上都能顺利运行。 ... [详细]
  • 几何画板展示电场线与等势面的交互关系
    几何画板是一款功能强大的物理教学软件,具备丰富的绘图和度量工具。它不仅能够模拟物理实验过程,还能通过定量分析揭示物理现象背后的规律,尤其适用于难以在实际实验中展示的内容。本文将介绍如何使用几何画板演示电场线与等势面之间的关系。 ... [详细]
  • 本文介绍如何在应用程序中使用文本输入框创建密码输入框,并通过设置掩码来隐藏用户输入的内容。我们将详细解释代码实现,并提供专业的补充说明。 ... [详细]
  • 本文详细介绍了如何通过命令行启动MySQL服务,包括打开命令提示符窗口、进入MySQL的bin目录、输入正确的连接命令以及注意事项。文中还提供了更多相关命令的资源链接。 ... [详细]
  • 本文探讨了如何通过最小生成树(MST)来计算严格次小生成树。在处理过程中,需特别注意所有边权重相等的情况,以避免错误。我们首先构建最小生成树,然后枚举每条非树边,检查其是否能形成更优的次小生成树。 ... [详细]
  • 深入理解OAuth认证机制
    本文介绍了OAuth认证协议的核心概念及其工作原理。OAuth是一种开放标准,旨在为第三方应用提供安全的用户资源访问授权,同时确保用户的账户信息(如用户名和密码)不会暴露给第三方。 ... [详细]
  • 国内BI工具迎战国际巨头Tableau,稳步崛起
    尽管商业智能(BI)工具在中国的普及程度尚不及国际市场,但近年来,随着本土企业的持续创新和市场推广,国内主流BI工具正逐渐崭露头角。面对国际品牌如Tableau的强大竞争,国内BI工具通过不断优化产品和技术,赢得了越来越多用户的认可。 ... [详细]
  • 深入理解 Oracle 存储函数:计算员工年收入
    本文介绍如何使用 Oracle 存储函数查询特定员工的年收入。我们将详细解释存储函数的创建过程,并提供完整的代码示例。 ... [详细]
  • 本文介绍如何通过Windows批处理脚本定期检查并重启Java应用程序,确保其持续稳定运行。脚本每30分钟检查一次,并在需要时重启Java程序。同时,它会将任务结果发送到Redis。 ... [详细]
  • MySQL中枚举类型的所有可能值获取方法
    本文介绍了一种在MySQL数据库中查询枚举(ENUM)类型字段所有可能取值的方法,帮助开发者更好地理解和利用这一数据类型。 ... [详细]
  • 本文介绍如何通过SQL查询从JDE(JD Edwards)系统中提取所有字典数据,涵盖关键表的关联和字段选择。具体包括F0004和F0005系列表的数据提取方法。 ... [详细]
  • 本文介绍如何使用 NSTimer 实现倒计时功能,详细讲解了初始化方法、参数配置以及具体实现步骤。通过示例代码展示如何创建和管理定时器,确保在指定时间间隔内执行特定任务。 ... [详细]
author-avatar
不会遗忘528_757
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有