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

Jvm实际运行情况-JVM(十七)

上篇文章说jmap和jstat的命令,如何查看youngGc和FullGc耗时和次数。

Jmap-JVM(十六)

  • Jvm实际运行情况

背景:

机器配置:2核4G

JVM内存大小:2G

系统运行天数:7天

期间发生FULL GC次数和耗时:500多次,200多秒

期间发生Yoing GC次数和耗时:1万多次,500多秒

算下来fullGC平均耗时,0.4s(每次400ms左右)

每天发生1万多次,则每分钟发生1次,每次YoungGC耗费50ms

JVM参数配置:

-Xms1536M -Xmx1536M -Xmn512M -Xss256K -XX:SurvivorRatio=6

-XX:MetaspaceSize=256M -XX:MaxMetaspaceSize=256M

-XX:+UseParNewGC -XX:+UseConcMarkSweepGC

-XX:CMSInitiatingOccupancyFraction=75 -XX:UseCMSInitiatingOccupancyOnly

通过以上参数我们可以分析出:

  1. 堆内存是1个G+512M
  2. 年轻代是512M,老年代是1G
  3. 因为比例是6:1:1,年轻代eden则是384M,S0和S1分别是64M
  4. 线程栈256K,元空间256M

前面我们说过,

  1. 大对象会进入老年代。
  2. 对象年龄太大会进入老年代。
  3. 对象动态年龄判断,当进入对象大小大于这块survivor区域的百分之50,会把大于年龄1的对象都放入老年代。
  4. 老年代分配担保机制:每次minor gc之前都会jvm计算老年代剩余可用空间,如果这个可用空间小于年轻代里现在所有对象大小之和(包括垃圾对象),就会看参数

-XX:HandlerPromotionFailure是否设置。如果没有设置,则直接fullGC,如果fullGC完还不能,则会发生OOM。

如何设置了,则会看老年代可用空间大小是否小于每次minor gc对象平均大小。大于的话才会minor gc。

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

相关文章:

  • 【BASH】回顾与知识点梳理(二)
  • 【分布式训练】Accelerate 多卡训练,单卡评测,进程卡住的解决办法
  • 时间复杂度为O(nlogn)的两种排序算法
  • java调用onnx模型,支持yolov5和yolov7
  • DP-GAN损失
  • 自监督去噪:Noise2Void原理和调用(Tensorflow)
  • Mac 安装配置adb命令环境(详细步骤)
  • GDAL C++ API 学习之路 (2) GDALRasterBand篇 代码示例 翻译 自学
  • springboot对静态资源的支持
  • WPF实战学习笔记27-全局通知
  • openSUSE安装虚拟化 qemu kvm
  • 基于linux下的高并发服务器开发(第四章)- 多进程实现并发服务器(回射服务器)
  • 【程序分析】符号执行
  • 实验笔记之——Windows下的Android环境开发搭建
  • #rust taur运行报错#
  • 学习购药系统源码:从前端到后端的技术探索
  • 第九次CCF计算机软件认证
  • 【计算机网络】传输层协议 -- TCP协议
  • Mac上命令
  • 软件安全测试和渗透测试的区别在哪?安全测试报告有什么作用?
  • Android 从LibVLC-android到自编译ijkplayer播放H265 RTSP
  • 如何提升等保水平,减少数据泄露率
  • 蓝桥云课ROS机器人旧版实验报告-07外设
  • sql入门基础-2
  • uni-app:实现表格多选及数据获取
  • 【图论】树上差分(点差分)
  • 【wrk2】轻量级性能测试工具
  • 华为云低代码平台Astro Canvas 搭建汽车展示大屏——实验指导手册
  • Nodejs 第七章(发布npm包)
  • Spring?Boot项目如何优雅实现Excel导入与导出功能