阅读本文之前请先了解JVM 基础知识
(https://www.jianshu.com/p/229a9307635a)
ROW title
Application: 项目名称
服务的名称,每个接口都对应着不同的服务,甚至会涉及多个服务,观测前需要知道所要监控的服务名称针对性的查看。
Instance:实例
服务下所对应机器的ip,一个服务一般会对应多台机器,在服务运行时会根据对应的负载均衡策略选择使用的机器及总数,选择某一台设备即可查看该设备的各项监控指标。
System Cpu Usage
该服务下各设备的CPU使用率波形图,右侧current显示的是当前的使用率。
I/O Detail
QPS 每秒请求数量
服务端实际每秒接收的请求数量 。
Average Latency 平均等待时间
请求处理时长(min:最小值,max:最大值,avg:平均值,current:实时)
JVM Memory JVM内存
JVM heap JVM堆
Java 虚拟机具有一个堆,堆是运行时数据区域,所有类实例和数组的内存均从此处分配。堆是在 Java 虚拟机启动时创建的。对象的堆内存由称为垃圾回收器的自动内存管理系统回收。
JVM heap Non-JVM堆
Java 虚拟机管理堆之外的内存(称为非堆内存),Java 虚拟机具有一个由所有线程共享的方法区。方法区属于非堆内存。它存储每个类结构,如运行时常数池、字段和方法数据,以及方法和构造方法的代码。它是在 Java 虚拟机启动时创建的。
JVM Total JVM 内存使用总量
used是已经被使用的内存大小,committed是当前可使用的内存大小(包括已使用的),committed >= used。committed不足时jvm向系统申请,若超过max则发生OutOfMemoryError错误。max是内存最大值。
JVM Misc
CPU Usage
system:CPU花了多少比例的时间在内核空间运行。分配内存、IO操作、创建子进程……都是内核操作
pod=‘xxx’:指定机器的cou使用率
load
cpu负载:负载表示的是“等待进程的平均数”,运行态(running)和不可中断状态(interruptible)才会被加入到负载等待进程中,具体为下面两种情况:
- 即便需要立即使用CPU,也还需等待其他进程用完CPU
- 即便需要继续处理,也必须等待磁盘输入输出完成才能进行
Thread 线程
live:存活的线程
damon threads:守护线程
守护线程又称为“服务线程”。在没有用户线程可服务时会自动离开。****守护线程的优先级比较低,用于为系统中的其它对象和线程提供服务。
垃圾回收线程就是一个经典的守护线程,当我们的程序中不再有任何运行的Thread,程序就不会再产生垃圾,垃圾回收器也就无事可做,所以当垃圾回收线程是JVM上仅剩的线程时,垃圾回收线程会自动离开。它始终在低级别的状态中运行,用于实时监控和管理系统中的可回收资源。
peak threads:峰值
thread states 线程状态
new:至今尚未启动的线程的状态。线程刚被创建,但尚未启动。
blocked :受阻塞并且正在等待监视器的某一线程的线程状态。处于受阻塞状态的某一线程正在等待监视器锁,以便进入一个同步的块/方法,或者在调用 Object.wait 之后再次进入同步的块/方法。
runnable:可运行线程的线程状态。线程正在JVM中执行,有可能在等待操作系统中的其他资源,比如处理器。
timed_waiting:指定了等待时间的某一等待线程的线程状态。线程正在等待另一个线程来执行某一个特定的操作,并设定了指定等待的时间,线程因为调用下面的方法之一而处于定时等待状态:
- Thread.sleep 方法
- 指定超时值的 Object.wait 方法
- 指定超时值的 Thread.join 方法
- LockSupport.parkNanos
- LockSupport.parkUntil
waitting:某一等待线程的线程状态。线程正在无期限地等待另一个线程来执行某一个特定的操作,线程因为调用下面的方法之一而处于等待状态:
- 不带超时的 Object.wait 方法,日志中显示为 java.lang.Thread.State: WAITING (on object monitor)
- 不带超时的 Thread.join 方法
- LockSupport.park 方法,日志中显示为 java.lang.Thread.State: WAITING (parking)
terminated: 线程处于终止状态。
ps:根据Java Doc中的说明,在给定的时间上,一个只能处于上述的一种状态之中,并且这些状态都是JVM的状态,跟操作系统中的线程状态无关。
Log Events
每分钟上报的日志数量
TOMCAT 线程数
BSY: 繁忙线程数(当前正在运行的线程/正在处理的线程)
CUR: 当前启用的线程数;
MAX: 最大线程数
File Descriptors 描述文件
fd是一个非负整数,一个索引值,指向内核为每一个进程所维护的该进程打开文件的记录表。
程序打开一个现有文件或者创建一个新文件,内核向该进程返回一个文件描述符。
JVM Memory Pools(Heap)
内存分区
CMS old Gen:老年代
一般情况新创建的对象会放到新生代中,只有经过一定次数的GC后还没有被回收的对象,我们认为这部分对象在未来也会长时间存在,所以会把这部分的对象转移到老年代的区域中去。
par Eden space:新生代
par survivor space:新生代
GC把垃圾对象回收后如果不对存活下来的对象进行整理,那么就会出现很多不连续的内存空间,这也就是我们常说的空间碎片,因为没有连续的空间分配,这样就可能造成我们一个大对象过来我们没有对应的连续空间分配,但是内存里其实是有能够容纳对象的总空间的。
所以为了减少这种空间碎片,我们就使用了另一种方式,把新生代分为了Eden 区和Survior 区,在进行垃圾回收时,先把存活的对象复制到 Survior 区,然后再对Eden区统一进行清理,这样的话Eden区每次GC过后都是留下的一片连续的空间。
JVM Memory Pools(Non-Heap)
非堆内存也叫做PermGen space(永久代),与新生代和老年代概念对齐,就是说是永久保存的区域,用于存放Class和Meta信息,Class在被Load的时候被放入该区域,GC应该不会对PermGen space进行清理。
metaspace: 元空间
元空间包含类的其它比较大的元数据,比如方法,字节码,常量池等。
compressed class space 类指针压缩空间
类指针压缩空间只包含类的元数据,比如InstanceKlass, ArrayKlass 仅当打开了UseCompressedClassPointers选项才生效 为了提高性能,Java中的虚方法表也存放到这里 这里到底存放哪些元数据的类型,目前仍在减少
code cache 代码缓存区
用于编译和保存本地代码
Garbage Collection
collections
end of minor GC:年轻代中的GC
ops/sec:每秒操作数
pause durations
垃圾回收持续暂停时间
Allocated/Promoted
Allocated:已分配的资源大小
Promoted:从新生代提升到老年代的资源大小
Classloading
classes loaded:类加载
Buffer Pools
DirectBuffer
DirectBuffer 占用的是 堆外内存。JVM 会在 DirectBuffer 上直接使用 “本地IO操作”(Native I/O Operations)。
MappedByteBuffer
MappedByteBuffer 可以 将文件内容映射到内存,供应用程序直接使用,省去数据在 内核空间 和 用户空间 之间传输的损耗。