当前位置: 首页 > news >正文

Java性能优化-GC优化基础

GC优化基础

调整堆大小

如果在FULL GC系统进行了交换,停顿时间会增长几个数量级,OS
如果G1 GC和后台进程处理堆,将会出现等待数据从磁盘复制到主内存时间较长,速度和下降并且并发模式可能失效
linux 关闭交换区
swapoff -a
linux默认 512M 适用于大多数应用,如果我们不了解参数配置则不应该调整(know-well)
除非应用程序需要更大的堆,否则优化GC算法的性能目标而不是调整堆大小@know what that mean?

调整分代大小

确定了堆的大小JVM就需要将多少分配给新生代
代的不同大小的性能含义:程序运行时的平衡点—架构能力
如果新生代大,YGC停顿时间会增加,回收频率会减低
老年代小,填满的概率搞,FULL GC,STW停顿时

设置新生代和老年代的比例 默认值2
-XX:NewRatio=N
新生代初始大小=堆的初始大小 / (1 + NewRatio)
-Xmx512m -Xms512m -XX:NewRatio=2
512 / (1 + 2) = 170M 初始大小公式实例

设置新生代的初始值,新生代初始大小是对的33%
-XX:NewSize=N

设置新生代的最大值
-XX:MaxNewSize=N

-XmnN
将NewSize和MaxNewSize设置为同一个值的简单写法

JVM如何调整应用程序内空间大小
XX:+PrintAdaptiveSizePolicy

在堆的总体大小内,各个代的大小由分配新生代的空间多少控制

调整元空间大小

当JVM加载类必须记住这些类的某些元数据,这些数据单独占据了一个空间叫作元空间。

控制并行

除了Serial回收器,其他GC算法都使用多线程技术
-XX:ParallelGCThreads=N 这个标志的影响范围
8 + ((N - 8) * 5 / 8)
-XX:+UseParallelGC 新老年代的回收

http://www.lryc.cn/news/16852.html

相关文章:

  • 【Tomcat】IDEA编译Tomcat源码-手把手教程
  • 如何弄小程序?公司企业可以这样做小程序
  • 【Git】IDEA集合Git和码云
  • [USACO03FALL / HAOI2006] 受欢迎的牛 G(C++,强连通分量)
  • Vue 动态路由接口数据结构化为符合VueRouter的声明结构及菜单导航结构、动态路由懒加载方法
  • Python----------字符串
  • 日志收集笔记(架构设计、Log4j2项目初始化、Lombok)
  • 一文教你玩转 Apache Doris 分区分桶新功能|新版本揭秘
  • 数据挖掘,计算机网络、操作系统刷题笔记54
  • 将数组中的每个元素四舍五入到指定的精度numpy.rint()
  • Web安全之服务器端请求伪造(SSRF)类漏洞详解及预防
  • LeetCode:239. 滑动窗口最大值
  • JS 函数参数(动态参数、剩余参数)
  • 365天深度学习训练营-第J3周:DenseNet算法实战与解析
  • Parisland NFT 作品集
  • uniapp: 基础开发官网文档
  • mybatis中配置连接池的原理介绍分析
  • 二叉树——路径总和
  • WebDAV之π-Disk派盘+文件管理器
  • form表单单输入框回车提交事件处理
  • c++常用stl算法
  • 非对称密钥PKCS#1和PKCS#8格式互相转换(Java)
  • java获取当前时间的方法:LocalDateTime、Date、Calendar,以及三者的比较
  • npm link
  • Docker 如何配置镜像加速
  • 阅读笔记7——Focal Loss
  • ZCMU--5009: 龙虎斗
  • 创建项目(React+umi+typeScript)
  • FISCO BCOS(二十七)———java操作WeBase
  • 失眠时还在吃它?有风险,你了解过吗