进学阁

业精于勤荒于嬉,行成于思毁于随

0%

1 查看JVM参数

1.1 使用Java命令

官网地址:The java Command

JAVA Program arguments和VM options区别?

在Java中,Program arguments和VM options是两个不同的概念,它们各自扮演着不同的角色。

  1. Program arguments是程序参数,也就是传递给Java主类中的main方法的字符串数组args[]。这些参数通常以“–”开头,如“–server.port=8099”,用于为应用程序提供特定的输入或配置。Program arguments是通用的,不依赖于特定的虚拟机设置,因此,即使不是使用Java编写的程序,也可以采用类似的方式来传递参数。然而,处理这些参数可能会稍显复杂,通常需要借助第三方库或自行编写解析逻辑。

springboot会识别到它的设置并更改到yaml配置文件中。


阅读全文 »

1 工具概述

使用上一章命令行工具或组合能帮您获取目标 Java 应用性能相关的基础信息,但它们存在下列局限:

  • 1.无法获取方法级别的分析数据,如方法间的调用关系、各方法的调用次数和调用时间等(这对定位应用性能瓶颈至关重要)。
  • 2.要求用户登录到目标 Java 应用所在的宿主机上,使用起来不是很方便。
  • 3.分析数据通过终端输出,结果展示不够直观。

为此,JDK 提供了一些内存泄漏的分析工具,如 jconsole,jvisualvm 等,用于辅助开发人员定位问题,但是这些工具很多时候并不足以满足快速定位的需求。所以这里我们介绍的工具相对多一些、丰富一些。

阅读全文 »

脑图地址:https://www.yuque.com/zhuyufei-x9kmd/feay0m/20924414

1 概述

MissP:jmap、jinfo、jstat、jstack、jps

性能诊断是软件工程师在日常工作中需要经常面对和解决的问题,在用户体验至上的今天,解决好应用的性能问题能带来非常大的收益。

Java 作为最流行的编程语言之一,其应用性能诊断一直受到业界广泛关注。可能造成 Java 应用出现性能问题的因素非常多,例如线程控制、磁盘读写、数据库访问、网络 I/O、垃圾收集等。想要定位这些问题,一款优秀的性能诊断工具必不可少。

体会 1:使用数据说明问题,使用知识分析问题,使用工具处理问题。

体会 2:无监控、不调优!

阅读全文 »

1. 概述

类加载器是JVM执行类加载机制的前提。

ClassLoader的作用:

ClassLoader是Java的核心组件,所有的Class都是由ClassLoader进行加载的,ClassLoader负责通过各种方式将Class信息的二进制数据流读入JVM内部,转换为一个与目标类对应的java.lang.Class对象实例。然后交给Java虚拟机进行链接、初始化等操作。因此,ClassLoader在整个装载阶段,只能影响到类的加载,而无法通过ClassLoader去改变类的链接和初始化行为。至于它是否可以运行,则由Execution Engine决定。

阅读全文 »

1. 概述

在 Java 中数据类型分为基本数据类型和引用数据类型。基本数据类型由虚拟机预先定义,引用数据类型则需要进行类的加载。

按照 Java 虚拟机规范,从 class 文件到加载到内存中的类,到类卸载出内存为止,它的整个生命周期包括如下 7 个阶段:

其中,验证、准备、解析 3 个部分统称为链接(Linking)

从程序中类的使用过程看

阅读全文 »

1 虚拟机的基石:字节码指令

class类的本质

任何一个Class文件都对应着唯一一个类或接口的定义信息,但反过来说,Class文件实际上它并不一定以磁盘文件的形式存在(如网路传输),**简而言之Class 文件是一组以8位字节为基础单位的二进制流**。

class类的结构

class的结构不像XML等描述语言,由于它没有任何分隔符号。所以在其中的数据项,无论是字节顺序还是数量,都是被严格限定的,哪个字节代表什么含义,长度是多少,先后顺序如何,都不允许改变。

class文件格式采用一种类似于c语言结构体的方式进行数据存储,这种结构中只有两种数据类型:无符号数和表。

  • 无符号数属于基本的数据类型,以u1、u2、u4、u8 来分别代表1个字节、2个字节、4个字节和8个字节的无符号数,无符号数可以用来描述数字、索引引用、数量值或者按照UTF-8编码构成字符串值。
  • 表是由多个无符号数或者其他表作为数据项构成的复合数据类型,所有表都习惯性地以“_info”结尾。表用于描述有层次关系的复合结构的数据,整个Class文件本质上就是一张表。由于表没有固定长度,所以通常会在其前面加上个数说明。
    阅读全文 »

日志概述

通过阅读 Gc 日志,我们可以了解 Java 虚拟机内存分配与回收策略。 内存分配与垃圾回收的参数列表

  • -XX:+PrintGC 输出 GC 日志。类似:-verbose:gc
  • <font style="background-color:#FADB14;">-XX:+PrintGCDetails</font> 输出 GC 的详细日志
  • -XX:+PrintGCTimestamps 输出 GC 的时间戳(以基准时间的形式)
  • -XX:+PrintGCDatestamps 输出 GcC 的时间戳(以日期的形式,如 2013-05-04T21:53:59.234+0800)
  • -XX:+PrintHeapAtGC 在进行 GC 的前后打印出堆的信息
  • -Xloggc:../logs/gc.log 日志文件的输出路径
阅读全文 »

1 GC 分类与性能指标

1.1 垃圾回收器概述

垃圾收集器没有在规范中进行过多的规定,可以由不同的厂商、不同版本的 JVM 来实现。

由于 JDK 的版本处于高速迭代过程中,因此 Java 发展至今已经衍生了众多的 GC 版本。

从不同角度分析垃圾收集器,可以将 GC 分为不同的类型。

阅读全文 »