热门标签 | 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


推荐阅读
  • 二维码的实现与应用
    本文介绍了二维码的基本概念、分类及其优缺点,并详细描述了如何使用Java编程语言结合第三方库(如ZXing和qrcode.jar)来实现二维码的生成与解析。 ... [详细]
  • 探讨如何在映射文件中处理重复的属性字段,以避免数据操作时出现错误。 ... [详细]
  • 3DSMAX制作超现实的体育馆模型
    这篇教程是向脚本之家的朋友介绍3DSMAX制作超现实的体育馆模型方法,教程制作出来的体育馆模型非常地不错,不过教程有点难度,需要有一定基础的朋友学习,推荐到脚本之家,喜欢的朋友可 ... [详细]
  • JavaScript 页面卸载事件详解 (onunload)
    当用户从页面离开时(如关闭页面或刷新页面),会触发 onunload 事件,此时可以执行预设的脚本。需要注意的是,不同的浏览器对 onunload 事件的支持程度可能有所不同。 ... [详细]
  • 默认情况下,Git 使用 Nano 编辑器进行提交信息的编辑,但如果您更喜欢使用 Vim,可以通过简单的配置更改来实现这一变化。本文将指导您如何通过修改全局配置文件来设置 Vim 作为默认的 Git 提交编辑器。 ... [详细]
  • 探索Java 11中的ZGC垃圾收集器
    Java 11引入了一种新的垃圾收集器——ZGC,由Oracle公司研发,旨在支持TB级别的内存容量,并保证极低的暂停时间。本文将探讨ZGC的开发背景、技术特点及其潜在的应用前景。 ... [详细]
  • 网络流24题——试题库问题
    题目描述:假设一个试题库中有n道试题。每道试题都标明了所属类别。同一道题可能有多个类别属性。现要从题库中抽取m道题组成试卷。并要求试卷包含指定类型的试题。试设计一个满足要求的组卷算 ... [详细]
  • 本文探讨了程序员这一职业的本质,认为他们是专注于问题解决的专业人士。文章深入分析了他们的日常工作状态、个人品质以及面对挑战时的态度,强调了编程不仅是一项技术活动,更是个人成长和精神修炼的过程。 ... [详细]
  • 在1995年,Simon Plouffe 发现了一种特殊的求和方法来表示某些常数。两年后,Bailey 和 Borwein 在他们的论文中发表了这一发现,这种方法被命名为 Bailey-Borwein-Plouffe (BBP) 公式。该问题要求计算圆周率 π 的第 n 个十六进制数字。 ... [详细]
  • 2023年,Android开发前景如何?25岁还能转行吗?
    近期,关于Android开发行业的讨论在多个平台上热度不减,许多人担忧其未来发展。本文将探讨当前Android开发市场的现状、薪资水平及职业选择建议。 ... [详细]
  • 本文介绍了SIP(Session Initiation Protocol,会话发起协议)的基本概念、功能、消息格式及其实现机制。SIP是一种在IP网络上用于建立、管理和终止多媒体通信会话的应用层协议。 ... [详细]
  • 我的读书清单(持续更新)201705311.《一千零一夜》2006(四五年级)2.《中华上下五千年》2008(初一)3.《鲁滨孙漂流记》2008(初二)4.《钢铁是怎样炼成的》20 ... [详细]
  • 本文详细介绍了C++中的构造函数,包括其定义、特点以及如何通过构造函数进行对象的初始化。此外,还探讨了转换构造函数的概念及其在不同情境下的应用,以及如何避免不必要的隐式类型转换。 ... [详细]
  • 数据类型--char一、char1.1char占用2个字节char取值范围:【0~65535】char采用unicode编码方式char类型的字面量用单引号括起来char可以存储一 ... [详细]
  • 本文详细介绍了iOS应用的生命周期,包括各个状态及其转换过程中的关键方法调用。 ... [详细]
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社区 版权所有