衡量系统性能的点
  • 执行速度:即响应时间
  • 内存分配:内存分配是否合理,是否过多消耗内存或者存在内存泄露
  • 启动时间:程序从启动到正常处理业务需要的时间
  • 负载承受能力:当系统压力上升,系统执行速度和响应时间上升曲线是否平缓

系统调优层次
  • 系统设计调优
  • 代码调优
  • jvm调优
  • 数据库调优
  • 操作系统调优

垃圾回收基础

垃圾回收算法:

  • 引用计数法:每个对象都有一个引用计数器,当被一个对象引用的时候计数器+1,当引用失效的时候计数器-1,当计数器为0的时候就可以被回收掉。这种算法的缺陷是,不能解决循环引用的问题,当A\B相互引用的时候,各自的引用计数器都为1,但是他们都没有被第三个对象所引用,所以是可以被回收掉的。由于由这种缺陷,引用计数法不适合JVM的垃圾回收。

  • 标记-清除算法:标记清除法是现代垃圾回收算法思想的基础。从根节点开始,通过标记根节点开始所有可达的对象,标记完成后,对未标记的对象进行清除。这种算法的缺点是,清除后会出现不连续的内存区域。不连续的内存空间效率比连续的内存空间要低。

  • 复制算法:把内存区域分成2块。一块是正在使用的,一块是没有在使用的。当进行垃圾回收的时候,把存活的对象从正在使用的区域复制到非正在使用的区域,然后清除正在使用区域的所有对象,交换2个内存的角色完成垃圾回收。这样可用区域的内存就连续了。如果垃圾对象多余存活对象,这种方式效果就比较好。

    java新生代垃圾串行回收器使用了复制算法的思想。

  • 标记压缩算法:适合老年代回收算法。在标记清除法的基础上做了优化。当需要回收的对象比较少的时候,这种算法比较高效。标记完后,把存活的对象压缩到内存的一端,然后把垃圾对象清理,这样就避免了不连续区域。

  • 增量算法:对于大部分垃圾回收算法,垃圾回收的时候会stop the world,所有应用的线程都会挂起,导致停顿。增加的话,是分区域垃圾回收,减少垃圾回收的范围,然后再间歇运行下应用程序。

  • 分代:将内存区域根据对象特点分成几块,不同的块使用不同的垃圾回收算法。在Hot Spot虚拟机中,所有新建的对象都放到新生代,当一个对象经过几次回收仍然存活就放入老年代

内存区域 使用的算法
新生代 复制算法
老年代 标记压缩算法

JVM调优常见案例
  • 大对象进入老年代:新生的大对象如果放在新生带可能会扰乱新生代的内存回收,因为新生代如果被大对象挤满了,新产生的对象都会被挤过去老年代, -XX:PretenureSizeThreshold 设置大对象直接进入老年代的阈值。 如果进入了老年代,又比较短命的话,标记压缩算法又会很不利,所以如果短命的大对象太多,对垃圾回收是一种灾难。

  • 设置进入老年代的年龄:新生代进入老年代和年龄有关。新对象会放在eden区,如果经过一次回收仍然存活,则被放入survivior区,对象年龄增加1。如果年龄达到的阈值就会被挪到老年代。-XX:MaxTenuringThreshold 设置最大年龄。

  • 稳定与震荡的堆大小: 稳定的堆大小会减少GC的次数,因此有的人会设置最小堆内存和最大堆内存成一样的值。但是GC堆大的话也会影响单次GC的时间。因此出了Xmx和Xms外还提供了以下参数。当Xmx和Xms一样的时候以下参数无效。

参数 作用
-XX:MinHeapFreeRatio:40 堆空间最小空闲比例,默认是40。当空闲的小于40%的时候,会扩大堆空间,确保程序空闲的时候震荡不会太大。
-XX:MaxHeapFreeRatio:70 堆空间最大空闲比例,默认是70。当空闲的空间大于70%的时候,会压缩堆空间。

实用案例

  • 吞吐量优先案例(32核,4G)
启动参数 参数解析
-Xmx3800m -Xms3800m 减少堆震荡和频繁GC。吞吐量大,内存一般都会维持在较高水平
-Xss128k 减少线程栈大小,剩余的系统内存支持更多的线程。
-Xmn2g 设置新生代大小
-XX:UseParallelGC 新生代使用并行回收器
-XX:ParallelGCThreads=20 设置垃圾回收线程总数
-XX:UseParallelOldGC 老年代也使用并行回收器
  • 使用大叶案例:在Solaris系统中,jvm支持大页使用 -XX:LargePageSizeInBytes=256m

  • 降低停顿案例

启动参数 参数解析
-XX:ParallelGCThreads=20 设置垃圾回收线程总数
-XX:UseParallelGC 新生代使用并行回收器
-XX:UseConcMarkSweepGC 老年代使用CMS收集器降低停顿
-XX:SurvivorRatio=8 eden区:survivor区 = 8:1 稍大的survivor区,可以提高在新生代回收声明周期较短的对象的可能性,避免进入老年代
-XX:TargetSurvivor=90 设置survivor的可使用率为90%,默认是50%,提高了survivor区的实用率
-XX:MaxTenuringThreshold=31 设置年轻代进入老年代的年龄,默认是15,这里设置成31,尽可能地将对象保存在新生代

java程序性能优化读书笔记-垃圾回收的更多相关文章

  1. Java程序性能优化读书笔记(一):Java性能调优概述

    程序性能的主要表现点: 执行速度:程序的反映是否迅速,响应时间是否足够短 内存分配:内存分配是否合理,是否过多地消耗内存或者存在内存泄漏 启动时间:程序从运行到可以正常处理业务需要花费多少时间 负载承 ...

  2. Java程序性能优化-读书笔记(一) 单例模式

    单例模式: 目的: 确保系统中一个类只产生一个实例. 好处: 1.对于频繁使用的对象,可以省略创建对象所花费的时间,这对于那些重量级对象而言,是非常可观的一笔系统开销. 2.由于new操作的次数减少, ...

  3. [JAVA] java程序性能优化

    一.避免在循环条件中使用复杂表达式 在不做编译优化的情况下,在循环中,循环条件会被反复计算,如果不使用复杂表达式,而使循环条件值不变的话,程序将会运行的更快. 例子: import java.util ...

  4. Java程序性能优化技巧

    Java程序性能优化技巧 多线程.集合.网络编程.内存优化.缓冲..spring.设计模式.软件工程.编程思想 1.生成对象时,合理分配空间和大小new ArrayList(100); 2.优化for ...

  5. 《Java程序性能优化:让你的Java程序更快、更稳定》

    Java程序性能优化:让你的Java程序更快.更稳定, 卓越网更便宜,不错的书吧

  6. Java程序性能优化之性能概述

    性能的基本概念 一).什么叫程序的性能? 程序运行所需的内存和时间. 二).性能的表现形式: 1).执行速度: 程序的反应是否迅速,响应时间是否足够短. 2).启动时间:程序从运行到可以处理正常业务所 ...

  7. 《Java程序性能优化》学习笔记 设计优化

    豆瓣读书:http://book.douban.com/subject/19969386/ 第一章 Java性能调优概述 1.性能的参考指标 执行时间: CPU时间: 内存分配: 磁盘吞吐量: 网络吞 ...

  8. Java程序性能优化Tip

    本博客是阅读<java time and space performance tips>这本小书后整理的读书笔记性质博客,增加了几个测试代码,代码可以在此下载:java时空间性能优化测试代 ...

  9. java程序性能优化

    一.避免在循环条件中使用复杂表达式 在不做编译优化的情况下,在循环中,循环条件会被反复计算,如果不使用复杂表达式,而使循环条件值不变的话,程序将会运行的更快. 例子: import java.util ...

随机推荐

  1. windows下安装Mysql(图文详解)

      博客园 | 首页 | 新随笔 | 联系 | 订阅 | 管理 mysql安装过程及注意事项: 1.1. 下载: 我下载的是64位系统的zip包: 下载地址:https://dev.mysql.com ...

  2. September 21st 2017 Week 38th Thursday

    What fire does not destroy, it hardens. 烈火摧毁不了的东西,只会变得更坚固. The true gold can stand the test of fire, ...

  3. Django 错误之 No module named ‘MySQLdb’

    由于卸载Mysql时将很多相关依赖包都卸载了,重装mysql后启动django出现如下错误: django.core.exceptions.ImproperlyConfigured:Error loa ...

  4. OC中实现可变参数

    通过哨兵参数实现,相当于nil. 1.c语言中 #import <stdio.h> #import <stdarg.h> int addemUp(int firstNum,.. ...

  5. Python 2.7和3.6爬取妹子图网站单页测试图片

    1.url= http://www.mzitu.com/74100/x,2为1到23的值 2.用到模块 os 创建文件目录; re模块正则匹配目录名 图片下载地址; time模块 限制下载时间;req ...

  6. jQuery文字“橡皮圈“特效

    <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title> ...

  7. sql server 2000 错误229 拒绝了对象sysobjects 的select 权限

    此问题是权限问题,我的解决办法是因为添加角色的时候勾选太多导致的 !!!!!!千万不要勾选db_denydatareader.

  8. JPA条件查询时间区间用LocalDateTime的问题

    @Override public Page<Order> findAll(String outTradeNo, String tradeNo, String mchAppid, Strin ...

  9. 基于AppDomain的"插件式"开发

    很多时候,我们都想使用(开发)USB式(热插拔)的应用,例如,开发一个WinForm应用,并且这个WinForm应用能允许开发人员定制扩展插件,又例如,我们可能维护着一个WinService管理系统, ...

  10. linux 修改时间永久

    date -s "20190421 16:36:20" &&hwclock --systohc