JVM优化[通俗易懂]

JVM优化[通俗易懂]为什么要进行JVM优化?在本地开发环境中我们很少有需求对JVM进行优化,但是到了生产环境我们的程序可能出现如下问题:运行的引用“卡住了”,日志不输出,程序没反应服务器的CPU负载突然升高在多线程应用下,如何合理的分配线程的数量。。。。。。。。。通过Java-server和java-client设置JVM的运行参数serverVM的初始堆空间会大一些,默认使用的是并行垃圾回…

大家好,又见面了,我是你们的朋友全栈君。

为什么要进行JVM优化?

在本地开发环境中我们很少有需求对JVM进行优化,但是到了生产环境我们的程序可能出现如下问题:

  • 运行的引用“卡住了”,日志不输出,程序没反应
  • 服务器的CPU负载突然升高
  • 在多线程应用下,如何合理的分配线程的数量
  • 。。。。。。。。。

通过Java -server和java -client设置JVM的运行参数

  • server VM的初始堆空间会大一些,默认使用的是并行垃圾回收器,启动慢运行快
  • client VM初始堆空间相对较小,使用串行垃圾回收器,他的目标是为了让JVM的启动速度更快,但是运行速度相对较慢。
  • JVM在启动时会根据硬件和操作系统自动选择运行哪种类型的JVM。
    • 32位操作系统:
      • 如果是Windows操作系统,无论硬件如何都会使用client类型的jvm;
      • 如果是其他操作系统;如果内存在2G以上并且有2个以上CPU使用server类型,否则使用client类型
    • 64位:
      • 只有server,不支持client;
        在这里插入图片描述
        在这里插入图片描述

JVM运行参数-xint、-Xcomp、-Xmixed

-X参数
在这里插入图片描述

-Xint、Xcomp、-Xmixed

  • 在解释模式下,-Xint标记会强制JVM执行所有的字节码,会降低运行速度,通常低10倍或者更多。
  • -Xcomp参数与-Xint相反,它会使JVM在第一次使用时把所有的字节码编译成本地代码,从而带来最大程度的优化。
    • 而很多应用在使用-Xcomp也会有一些性能损失,但是比使用-Xint损失少,原因是-Xcomp没有让JVM启动JIT编译器的全部功能。JIT编译器可以对是否需要编译做判断,如果所有代码都进行编译的话,对于一些只执行一次的代码就没有意义了。
  • -Xmixed是混合模式,将解释模式预编译模式进行混合使用,由JVM自己决定
    ,这是JVM默认的模式,也是瑞建使用的模式。
  • 演示:
    在这里插入图片描述
    在这里插入图片描述
    在这里插入图片描述

-XX参数

  • -XX参数也是非标准参数,主要用于JVM调优和debug操作;
  • 两种类型:boolean类型;非boolean类型;
    • boolean类型
      • 格式:-XX:[±] 表示启用(+)或禁用(-)属性;
        • 如:-XX:+DisableExplicitGC 表示禁用手动调用gc操作
    • 非boolean类型
      • 格式:-XX=表示属性的值为
        • 如:-XX:NewRatio=1表示新生代和老年代的比值
          用法:
          在这里插入图片描述

-Xms与-Xmx参数

  • -Xms:JVM的堆内存的初始值大小;
    • -Xms512m:等价于-XX:InitalHeapSize,设置JVM初始堆内存为512m;
  • -Xmx:JVM的堆内存的最大大小;
    • -Xmx2048m:等价于-XX:MaxHeapsSize,设置JVM最大堆内存为2048m;
      演示:
      在这里插入图片描述

查看JVM的运行参数

  • 运行java命令时打印参数:添加-XX:+PrintFlagsFinal参数
  • 演示:
    参数过多截取部分!
    参数有boolean类型和数字类型,值的操作符是=或:=,分别代表默认值和被修改的值
    演示:
    在这里插入图片描述

查看正在运行的jvm参数

  • 启动一个tomcat用于测试
  • 访问成功后:
    在这里插入图片描述
    在这里插入图片描述

JVM内存模型

JDK1.7:

在这里插入图片描述
在这里插入图片描述

JDK1.8:

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

JDK1.7与1.8堆内存模型差异

  • 1.7原有的永久区被废除,取而代之的是1.8中的MetaSpace(元空间)
    • 废除是为了融合HotSpot JVM与JRockit VM
    • 现实使用中,由于永久代内存经常不够用或发生内存泄漏,爆出异常OutOfMemooryError,基于此,将永久废除,而改用元空间代替,改了是为了使用本地空间。

通过jstat命令查看堆内存的使用情况

  • 查看class加载统计
    在这里插入图片描述
    • loaded:加载class的数量
    • Bytes:所占用的空间
    • UNloaded:未加载数量
    • Bytes:未加载占用空间
    • Time:时间
  • 查看编译统计
    在这里插入图片描述
    • Compiled:编译数量
    • Failed:失败数量
    • Invalid:不可用数量
    • Time:时间
    • FailedType:失败类型
    • failedMethod:失败方法
  • 垃圾回收统计
    在这里插入图片描述
    在这里插入图片描述

jmap的使用以及内存溢出分析

  • 查看内存使用情况
    在这里插入图片描述
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/130518.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • pycharm实用快捷键注释大全(持续更新中)

    pycharm实用快捷键注释大全(持续更新中)Ctrl F1 显示错误描述或警告信息 Alt Enter 快速修正 Ctrl R 替换 Ctrl Shift F 或者连续 2 次敲击 shift 全局查找 可以在整个项目中查找某个字符串什么的 如查找某个函数名字符串看之前是怎么使用这个函数的 Ctrl Shift R 全局替换 Alt Shift F10 运行模式配置 Alt

    2025年7月3日
    5
  • 机房收费重构——关于面向对象和分层的纠结

    机房收费重构——关于面向对象和分层的纠结

    2021年11月15日
    40
  • hive sql语句和mysql用法区别存档

    hive sql语句和mysql用法区别存档写在前面以下功能版本:mysql版本:5.6.17hive版本:2.2.41、GROUP_CONCAT先看下面数据表test_group:(1)简单情况需求如下:写出一个sql语句,按照category分组,并把组内的name使用“;”分隔符连接。①mysql中SELECT category, GROUP_CONCAT(nameSEPARATOR";&quo

    2022年10月2日
    4
  • java的outputstream_java输入流

    java的outputstream_java输入流我有这个InputStream:InputStreaminputStream=newByteArrayInputStream(myString.getBytes(StandardCharsets.UTF_8));如何将其转换为ServletInputStream?我努力了:ServletInputStreamservletInputStream=(ServletInputStrea…

    2025年11月28日
    9
  • Camstar 刷新缓存服务CDO

    Camstar 刷新缓存服务CDO刷新缓存服务 CDO 一 定位到指定 CDO 使用指定 CDO 作为父类添加 SubClass 如下图所示 1 打开 Designer 打开 CDOs 窗体 点击 find2 在弹出的窗口输入 V4 Security 3 选中 V4 Security4 点击 Select 二 在指定的 CDO 创建 SubClass1 在第一步定位的 CDO 上右击 2 然后点击 AddSubclass

    2025年10月7日
    4
  • linux定时器编程实验报告,Linux定时器实验.doc[通俗易懂]

    linux定时器编程实验报告,Linux定时器实验.doc[通俗易懂]Linux定时器实验Linux第六次实验及分析报告实验要求:1)在用户态编写一个程序,该程序设定一个定时器,在时间到期的时候做出某种可观察的响应(方法不限)2)分析你的程序的实际执行借助了内核的哪些机制3)提交实验与分析报告一:在用户态编写一个程序,该程序设定一个定时器,在时间到期的时候做出某种可观察的响应(方法不限)G++进行编译运行结果如下:可见调用间隔定时器定时10秒成功!二:分析你的程序的…

    2022年7月26日
    9

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号