【jvm系列-13】jvm性能调优篇---参数设置以及日志分析

news2024/10/7 12:19:34

JVM系列整体栏目


内容链接地址
【一】初识虚拟机与java虚拟机https://blog.csdn.net/zhenghuishengq/article/details/129544460
【二】jvm的类加载子系统以及jclasslib的基本使用https://blog.csdn.net/zhenghuishengq/article/details/129610963
【三】运行时私有区域之虚拟机栈、程序计数器、本地方法栈https://blog.csdn.net/zhenghuishengq/article/details/129684076
【四】运行时数据区共享区域之堆、逃逸分析https://blog.csdn.net/zhenghuishengq/article/details/129796509
【五】运行时数据区共享区域之方法区、常量池https://blog.csdn.net/zhenghuishengq/article/details/129958466
【六】对象实例化、内存布局和访问定位https://blog.csdn.net/zhenghuishengq/article/details/130057210
【七】执行引擎,解释器、JIT即时编译器https://blog.csdn.net/zhenghuishengq/article/details/130088553
【八】精通String字符串底层机制https://blog.csdn.net/zhenghuishengq/article/details/130154453
【九】垃圾回收底层原理和算法以及JProfiler的基本使用https://blog.csdn.net/zhenghuishengq/article/details/130261481
【十】垃圾回收器的种类以及内部的执行原理https://blog.csdn.net/zhenghuishengq/article/details/130261481
【十一】jvm性能调优篇之命令行工具的基本使用https://blog.csdn.net/zhenghuishengq/article/details/130641456
【十二】jvm性能调优篇之GUI工具的基本使用https://blog.csdn.net/zhenghuishengq/article/details/130745931
【十三】jvm性能调优篇之参数设置以及日志分析https://blog.csdn.net/zhenghuishengq/article/details/130802703

JVM参数设置以及日志分析

  • 一,JVM参数设置以及日志分析
    • 1,JVM的参数设置
      • 1.1,标准参数选项
      • 1.2,-X参数选项
      • 1.3,-XX参数类型
    • 2,添加JVM参数
    • 3,常用的JVM的参数选项
  • 二,GC日志的分析

一,JVM参数设置以及日志分析

1,JVM的参数设置

1.1,标准参数选项

特点就是比较稳定,后续的版本也不会变化,以-开头。可以打开cmd可执行命令,输入java -help,就可以查看对应的命令,如可以通过-server和-client模式设置是客户端模式还是服务端模式

java -help

1.2,-X参数选项

非标准化参数,功能相对稳定,后续版本可能会发生变动,以-X开头。可以输入java -X ,就可以查看到对应的命令。如可以通过这个-Xmixed来作为执行引擎的混合模式,解释器+编译器。

java -X

还有一些如设置堆的初始大小,最大大小以及设置线程的大小等

-Xms10m -Xmx10m -Xss10m

1.3,-XX参数类型

也是非标准化参数,使用的自多的参数类型,功能相对不稳定,以-XX开头,一般用于开发和调试JVM。

又可以对这些指令进行分类,分成boolean类型和非boolean类型。boolean类型的通过+、- 加或者减来启用或者禁用某个属性,因为有的指令是默认开启或者默认关闭的。如下面的一些命令:

-XX:+UseParallelGc         选择垃圾收集器为并行垃圾收集器
-XX:+UseG1GC               启用G1收集器
-XX:+UseAdaptiveSizePolicy 自动选择新生代大小和相应的s区的比例
-XX:+PrintFlagsFinal       输出所有参数的名称和默认值

非boolean类型的如下

//key/value类型
-XX:NewSize=1024M          新生代初始大小
-XX:MaxGCPauseMillis=500   设置GC停顿时间:500ms
-XX:GCTimeRatio=19         设置吞吐量
-XX:NewRatio=2             设置新生代和老年代比例

2,添加JVM参数

如在运行一个jar包,可以设置堆的大小,gc的间隔以及打印日志等

java -Xms1024m -Xmx1024m -XX:PrintGcDetails -XX:+PrintGcTimeStamps -jar xx.jar

3,常用的JVM的参数选项

打印的相关参数有

-XX:PrintFlagsFinal        表示打印出XX选项在运行时程序生效的值
-XX:PrintFlagsInitial      表示打印出XX选项的默认值
-XX:PrintVMOptions         打印JVM参数

栈的相关参数有

-Xss1m                     设置每个线程栈的大小为1m

堆内存的相关参数

-Xms1024m -Xmx1024m        设置堆的初始大小和最大大小都是1024m
-Xmn2g                     设置的是年轻代的大小
-XX:NewRatio=4             设置老年代和新生代的比例,默认为2
-XX:NewSize=1g             设置年轻代的初始大小为1g
-XX:NewMaxSize=1g          设置年轻代的最大大小为1g

在堆中还有一个重要的参数设置,这个自动选择各区比例是开启的,所有有时查看到的eden区和s区的比例有时为6:1,这个比例是动态调整的,如果想让他的值为默认值8:1,就得将这个-XX:SurvivorRatio=8 开启

-XX:SurvivorRatio=8        设置Eden区和s区的比例,默认为8
-XX:+UseAdaptiveSizePolicy 自动选择各区比例

方法区的相关参数,由于jdk8以及之后实现这个方法区的方式都是元空间,因此只谈元空间的参数设置

-XX:MetaspaceSize          初始空间
-XX:MaxMetaspaceSize=8     最大空间
-XX:+UseCompressedOops     压缩对象 指针
-XX:CompressedClassSpaceSize        设置类的元空间大小,默认是1G

OutofMemory相关参数

-XX:+HeapDumpOnOutOfMemory 表示出现OOM时,生成一个堆的dump文件
-XX:HeapDumpBeforeFullGc   表示出现这个FullGc之前,生成heap的存储文件
-XX:HeapDumpPath=<path>    指定heap转存储文件的存储路径
-XX:OnOutOfMemoryError     指定一个可行性的程序或者脚本

垃圾收集相关选项

-XX:+UseSerialGC           指定新生代和老年代使用serial回收器
-XX:+UseParNewGC           手动指定ParNewGC作为新生代的回收器
-XX:ParallelGCThreads      限制线程数量,默认开启和CPU相同的线程数
-XX:+UseParallelGC         手动指定并使用Parallel作为并行收集器
-XX:+UseParallelOldGC      手动指定老年代都是使用并行回收器
-XX:GCTimeRatio            垃圾收集时间占总时间比例
-XX:+UseAdapaiveSizePolicy 自适应调节策略
-XX:+UseConcMarkSweepGC    手动指定CMS作为垃圾回收器
-XX:ParallelCMSThreads     设置CMS的线程数量
-XX:MaxGCPauseMillis       设置期望值达到的最大GC停顿时间
-XX:ParallelGCThread       设置STW时GC线程数的值,最多设置为8
-XX:UseG1GC                手动指定使用G1收集器执行内存回收任务
-XX:G1HeapRegionSize       设置每个region的分区大小
-XX:ConcGCThreads          设置并发标记的线程数

GC日志相关选项

-verbose:gc                输出GC日志信息
-XX:+PrintGC               输出GC日志信息
-XX:+PrintGCDetails        发生垃圾回收时打印内存回收的详细信息
-XX:+PrintHeapAtGC         每一次GC前和GC后,都打印堆信息
-XX:PrintGCTimeStamps      输出gc打印时间戳信息
-Xloggc <path>             将日志文件保存到指定的path路径下

其他参数

-XX:+DisableExplicitGC      禁用虚拟机执行System.gc()
-XX:+UseCodeCacheFlushing   清理一些编译的代码
-XX:+DoEscapeAnalysis       开启逃逸分析
-XX:+UseBiasedLocking       开启偏向锁
-XX:+UseTLAB                使用TLAB,默认是打开的
-XX:TLABSize                设置TLAB的大小

也可以通过java代码来获取jvm参数

/**
 * @author zhenghuisheng
 * @date : 2023/5/19
 */
public class JvmParamTest {
    public static void main(String[] args) {
        MemoryMXBean memorymbean = ManagementFactory.getMemoryMXBean();
        MemoryUsage usage = memorymbean.getHeapMemoryUsage();
        System.out.println("INIT HEAP: " + usage.getInit());
        System.out.println("MAX HEAP: " + usage.getMax());
        System.out.println("USE HEAP: " + usage.getUsed());
        System.out.println("\nFull Information:");
        System.out.println("Heap Memory Usage: "
                + memorymbean.getHeapMemoryUsage());
        System.out.println("Non-Heap Memory Usage: "
                + memorymbean.getNonHeapMemoryUsage());

        List<String> inputArguments = ManagementFactory.getRuntimeMXBean().getInputArguments();
        System.out.println("===================java optiOns=============== ");
        System.out.println(inputArguments);



        System.out.println("=======================通过java来获取相关系统状态============================ ");
        int i = (int)Runtime.getRuntime().totalMemory()/1024;//Java 虚拟机中的内存总量,以字节为单位 
        System.out.println("总的内存量 i is "+i);
        int j = (int)Runtime.getRuntime().freeMemory()/1024;//Java 虚拟机中的空闲内存量 
        System.out.println("空闲内存量 j is "+j);
        System.out.println("最大内存量 is "+Runtime.getRuntime().maxMemory()/1024);

        System.out.println("=======================OperatingSystemMXBean============================ ");
        OperatingSystemMXBean osm = (OperatingSystemMXBean) ManagementFactory.getOperatingSystemMXBean();
        
        //获取操作系统相关信息 
        System.out.println("osm.getArch() "+osm.getArch());
        System.out.println("osm.getAvailableProcessors() "+osm.getAvailableProcessors());
        //System.out.println("osm.getCommittedVirtualMemorySize() "+osm.getCommittedVirtualMemorySize()); 
        System.out.println("osm.getName() "+osm.getName());
        //System.out.println("osm.getProcessCpuTime() "+osm.getProcessCpuTime()); 
        System.out.println("osm.getVersion() "+osm.getVersion());
        //获取整个虚拟机内存使用情况 
        System.out.println("=======================MemoryMXBean============================ ");
        MemoryMXBean mm=(MemoryMXBean)ManagementFactory.getMemoryMXBean();
        System.out.println("getHeapMemoryUsage "+mm.getHeapMemoryUsage());
        System.out.println("getNonHeapMemoryUsage "+mm.getNonHeapMemoryUsage());
        //获取各个线程的各种状态,CPU 占用情况,以及整个系统中的线程状况 
        System.out.println("=======================ThreadMXBean============================ ");
        ThreadMXBean tm=(ThreadMXBean)ManagementFactory.getThreadMXBean();
        System.out.println("getThreadCount "+tm.getThreadCount());
        System.out.println("getPeakThreadCount "+tm.getPeakThreadCount());
        System.out.println("getCurrentThreadCpuTime "+tm.getCurrentThreadCpuTime());
        System.out.println("getDaemonThreadCount "+tm.getDaemonThreadCount());
        System.out.println("getCurrentThreadUserTime "+tm.getCurrentThreadUserTime());

        //当前编译器情况 
        System.out.println("=======================CompilatiOnMXBean============================ ");
        CompilationMXBean gm=(CompilationMXBean)ManagementFactory.getCompilationMXBean();
        System.out.println("getName "+gm.getName());
        System.out.println("getTotalCompilationTime "+gm.getTotalCompilationTime());
        
        //获取运行时信息 
        System.out.println("=======================RuntimeMXBean============================ ");
        RuntimeMXBean rmb=(RuntimeMXBean)ManagementFactory.getRuntimeMXBean();
        System.out.println("getClassPath "+rmb.getClassPath());
        System.out.println("getLibraryPath "+rmb.getLibraryPath());
        System.out.println("getVmVersion "+rmb.getVmVersion());
    }
}

其打印结果如下

INIT HEAP: 268435456
MAX HEAP: 3799515136
USE HEAP: 8061840

Full Information:
Heap Memory Usage: init = 268435456(262144K) used = 8061840(7872K) committed = 257425408(251392K) max = 3799515136(3710464K)
Non-Heap Memory Usage: init = 2555904(2496K) used = 5345064(5219K) committed = 8060928(7872K) max = -1(-1K)
===================java optiOns=============== 
[-javaagent:D:\idea\IntelliJ IDEA 2019.1\lib\idea_rt.jar=58982:D:\idea\IntelliJ IDEA 2019.1\bin, -Dfile.encoding=UTF-8]
=======================通过java来获取相关系统状态============================ 
总的内存量 i is 251392
空闲内存量 j is 243519
最大内存量 is 3710464
=======================OperatingSystemMXBean============================ 
osm.getArch() amd64
osm.getAvailableProcessors() 4
osm.getName() Windows 10
osm.getVersion() 10.0
=======================MemoryMXBean============================ 
getHeapMemoryUsage init = 268435456(262144K) used = 8061840(7872K) committed = 257425408(251392K) max = 3799515136(3710464K)
getNonHeapMemoryUsage init = 2555904(2496K) used = 5396384(5269K) committed = 8060928(7872K) max = -1(-1K)
=======================ThreadMXBean============================ 
getThreadCount 6
getPeakThreadCount 6
getCurrentThreadCpuTime 375000000
getDaemonThreadCount 5
getCurrentThreadUserTime 187500000
=======================CompilatiOnMXBean============================ 
getName HotSpot 64-Bit Tiered Compilers
getTotalCompilationTime 28
=======================RuntimeMXBean============================ 

二,GC日志的分析

GC按照回收区域主要分为两大类型:一种是部分收集,一种是整堆收集。 部分收集的意思就是不是完整收集整个java堆的垃圾收集,比如有新生代的Minor GC、老年代的MajorGC;整堆收集就是收集整个Java堆和方法区的垃圾收集,比如有Full GC。

触发Full GC的场景如下:老年代的空间不足、方法区的空间不足、显式调用System.GC()、Minor GC进入老年代的平均大小大于老年代的可用内存大小、大对象直接进入老年代

在GC中,一般会有三个时间:user、sys、real。

  • user表示的是用户态所使用的时间,这是执行此进程所使用的实际CPU时间。
  • sys表示的是内核态消耗的时间,即在内核系统调用或等待系统事件所使用的CPU时间
  • real是程序开始到结束的时间。

如下面是一段线上服务的GC日志信息

Heap:
 PSYoungGen      total 1560576K, used 202793K [0x0000000755580000, 0x00000007c0000000, 0x00000007c0000000)
  eden space 1376768K, 13% used [0x0000000755580000,0x000000076115da18,0x00000007a9600000)
  from space 183808K, 5% used [0x00000007b4c80000,0x00000007b56accb0,0x00000007c0000000)
  to   space 185344K, 0% used [0x00000007a9600000,0x00000007a9600000,0x00000007b4b00000)
 ParOldGen       total 3495424K, used 80041K [0x0000000680000000, 0x0000000755580000, 0x0000000755580000)
  object space 3495424K, 2% used [0x0000000680000000,0x0000000684e2a410,0x0000000755580000)
 Metaspace       used 93746K, capacity 98782K, committed 99608K, reserved 1136640K
  class space    used 11338K, capacity 12190K, committed 12328K, reserved 1048576K

GC日志的格式规律一般都是:GC前内存占用 —> GC后内存占用(总内存)

[PSYoungGen5986K -> 696K(8704K)] 5986K -> 704K(9216K)

GC失败的场景

[GC (Allocation Failure) [PSYoungGen: 2240K->384K(2560K)] 4803K->2947K(9728K), 0.0006347 secs]

也可以使用一些GC工具进行日志分析,如GC EasyGC View工具等等。如下面是一个GC Easy的官网,其地址为:https://gceasy.io/,选择对应的log文件即可

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-xblxYu63-1684723839903)(img/1684721455060.png)]

在选择文件之后,就可以进入到下面的页面,从上往下滑就可以查看对应的详细信息

在这里插入图片描述

在all Thread这里,可以发现这现线程的状态,正处于阻塞状态
在这里插入图片描述
总而言之,这款工具还是挺好使用的

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/554232.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

【腾讯云FinOps Crane 集训营】让我看看还有谁没用过crane这个降本利器

近几年云原生概念的发展如雨后春笋&#xff0c;势如破竹&#xff0c;而devops和k8s(Kubernetes)两兄弟也搭上云原生的车先后火了起来 devops&#xff1a;如字面意思Development&Operations&#xff0c;它的理念是开发即运维&#xff0c;目的是消除开发者们与运维之间的隔阂…

OpenCV:从 CMake 产生 VS2019 项目和解决方案

CMake 是一个跨平台的自动化编译程序&#xff0c;它用于管理代码的构建过程。使用 CMake 可以简化跨平台项目的构建和移植&#xff0c;提供简单而强大的语法来描述构建过程&#xff0c;并生成多种不同的构建系统&#xff0c;如 GNU Make、Ninja 和 Visual Studio。因为 CMake 具…

shell编程(编写、执行,shell变量、传参、字符串、运算符使用)

来认识一下吧 Shell 是一个用 C 语言编写的程序&#xff0c;通过 Shell 用户可以访问操作系统内核服务。 Shell 既是一种命令语言&#xff0c;又是一种程序设计语言。 Shell script 是一种为 shell 编写的脚本程序。Shell 编程一般指 shell 脚本编程&#xff0c;不是指开发 she…

Python实现ACO蚁群优化算法优化卷积神经网络回归模型(CNN回归算法)项目实战

说明&#xff1a;这是一个机器学习实战项目&#xff08;附带数据代码文档视频讲解&#xff09;&#xff0c;如需数据代码文档视频讲解可以直接到文章最后获取。 1.项目背景 蚁群优化算法(Ant Colony Optimization, ACO)是一种源于大自然生物世界的新的仿生进化算法&#xff0c…

快速部署一套K8s集群-参考阿良老师

1、前置知识点 1.1 生产环境可部署Kubernetes集群的两种方式 目前生产部署Kubernetes集群主要有两种方式&#xff1a; kubeadm Kubeadm是一个K8s部署工具&#xff0c;提供kubeadm init和kubeadm join&#xff0c;用于快速部署Kubernetes集群。 二进制包 从github下载发行…

节省维护成本,提高效率!接口自动化测试框架热加载技术解析

目录 一、简介 二、实现热加载技术的具体操作 1. 借助Java类加载器实现热加载 2. 应用热加载技术动态更新代码 三、封装热加载技术 四、总结 前言 现如今&#xff0c;接口自动化测试已经成为了软件开发过程中不可或缺的一部分&#xff0c;通过使用接口自动化框架可以在效…

cpp 类成员函数delete this 会发生什么?

如题 this 简介: 每个非静态的类成员函数默认参数都会压栈一个this&#xff0c;它指向的是调用改成员函数的对象, 也是就className的object this 被隐含声明为 className* const this&#xff1b; 1.意味着不能改变this的指向2.this是个右值,不能取地址 ,不能&this 那我…

vue实现用户动态权限登录

一、使用vueelementUI搭登录框架&#xff0c;主要就是1、2、3、4 配置&#xff1a; ①vue.config.js use strict const path require(path)function resolve(dir) {return path.join(__dirname, dir) }// All configuration item explanations can be find in https://cli.v…

想自学写个操作系统,有哪些推荐看的书籍?

前言 哈喽&#xff0c;我是子牙&#xff0c;一个很卷的硬核男人。喜欢研究底层&#xff0c;聚焦做那些大家想学没地方学的课程&#xff1a;手写操作系统、手写虚拟机、手写编程语言… 今天我们将站在一个自学者的角度来聊聊如何实现自己的操作系统。并为大家推荐几本能够帮助你…

Ubuntu20.04配置静态IP地址,开启远程连接

本文操作演示为windows系统使用虚拟机安装的ubuntu系统进行&#xff1a;操作系统为ubuntu20.04&#xff0c;VMware15.5.0 build-14665864&#xff0c;内容分为两部分&#xff0c;第一部分为配置ubuntu系统的静态ip地址&#xff0c;第二部分内容为修改配置开启远程连接功能 一、…

第16章_变量、流程控制与游标

第16章_变量、流程控制与游标 1. 变量 在MySQL数据库的存储过程和函数中&#xff0c;可以使用变量来存储查询或计算的中间结果数据&#xff0c;或者输出最终的结果数据。 在 MySQL 数据库中&#xff0c;变量分为系统变量以及用户自定义变量。 1.1 系统变量 1.1.1 系统变量分…

Ansys Lumerical | 对铁电波导调制器进行仿真应用

说明 在本例中&#xff0c;我们仿真了使用BaTiO2的铁电波导调制器&#xff0c;BaTiO2是一种折射率因外加电场而发生变化的材料。该器件的结构基于文献[1]。我们模拟并分析了给定工作频率下波导调制器的有效折射率与电压的关系。 背景 铁电波导由硅层和玻璃衬底上的BiTiO3&#…

《实战大数据》书评

前言 首先感谢 CSDN 社区图书馆 举办的“图书活动第四期”&#xff0c;让我获得了“《实战大数据——分布式大数据分析处理系统开发与应用》”这本书。收到此书之后&#xff0c;对里面的内容非常感兴趣&#xff0c;同时也充满的未知的期待。 当今时代&#xff0c;物联网、大数据…

第四章 数学知识

第四章 数学知识 初等数论二&#xff1a;https://www.acwing.com/blog/content/26394/ 质数 试除法判定质数 bool is_prime(int x) {if (x < 2) return false;for (int i 2; i < x / i; i )if (x % i 0)return false;return true; }试除法分解质因数 void divide…

第四十八天学习记录:工作相关:Qt resizeEvent 的诡异问题

今天&#xff0c;在做一个新项目时&#xff0c;发现一个诡异的问题。 在软件初次打开的时候&#xff0c;会调用一次resizeEvent(QResizeEvent *sizechangeevent)函数来对主界面控件大小以及位置进行一次调整。 但由于窗口在设计的时候用的一个大小&#xff0c;而在打开软件后…

基于全志D1-H的Tina Linux SPI主从通信验证实录

本文转载自&#xff1a;https://bbs.aw-ol.com/topic/3031 作者 whycan矿工-小叶 背景 主控: D1H板卡: 两块哪吒开发板(以下简称为主机, 从机)操作系统: Tina Linux 2.0 问题 验证D1H芯片SPI主从机通信. 硬件接线 主机SPI从机SPI19SPI1_MOSISPI1_MOSI1921SPI1_MISOSPI1_M…

Git切换用户;Git提交之后是别人的用户怎么办?

Git切换用户 前言解决方法1.删除计算机凭证2.Idea控制台切换 前言 前几天在入职之后&#xff0c;公司的电脑上仍然储存了之前用户的信息&#xff0c;比如git。 我在创建分支、提交代码的时候会遇到这样的问题&#xff1a; 登录的是我自己的账号&#xff0c;但是在git动态里缺…

借助TeeChart图表控件,创建本地静态、实时浏览器图表

Steema是全球领先的图表类控件公司&#xff0c;总部设在西班牙的巴塞罗那附近&#xff0c;Steema公司的VCL图表报表控件在全球拥有极高知名度。TeeChart可以在微软的Visual Studio、Office和.NET以及Java和PHP开发平台中使用&#xff0c;也可以作为本地Javascript-HTML5使用。 …

Python新手怎么兼职,用Python在家兼职赚钱的4个方法

随着人工智能技术的发展&#xff0c;各行各业都在发生着变化&#xff0c;每天AI&#xff08;人工智能&#xff09;新技术都在冲击着各行各业&#xff0c;比如WPS的智能设计、阿里的鲁班等等&#xff0c;总有一种干死干活不如早点掌握新技能的感觉&#xff0c;避免心中的小慌张。…

DAY 65 mysql的高可用之MHA集群

MHA概述 什么是 MHA MHA&#xff08;MasterHigh Availability&#xff09;是一套优秀的MySQL高可用环境下故障切换和主从复制的软件。 MHA 的出现就是解决MySQL 单点故障的问题。 MySQL故障切换过程中&#xff0c;MHA能做到0-30秒内自动完成故障切换操作。 MHA能在故障切换…