Java内存监控方法

Posted moshimowang

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Java内存监控方法相关的知识,希望对你有一定的参考价值。

1、JMX功能

1.1 介绍

JMX(Java Management Extensions,即Java管理扩展)是一个为应用程序、设备、系统等植入管理功能的框架。JMX可以跨越一系列异构操作系统平台、系统体系结构网络传输协议,灵活的开发无缝集成的系统、网络和服务管理应用。

所谓JMX,是Java Management Extensions(Java管理扩展)的缩写,是一个为应用程序植入管理功能的框架。用户可以在任何Java应用程序中使用这些代理和服务实现管理。

JMX架构图:

 

三层结构

1、 基础层:主要是Mbean,被管理的java bean

Mbean分为如下四中

类型

描述

standard MBean

这种类型的MBean最简单,它能管理的资源(包括属性,方法,时间)必须定义在接口中,然后MBean必须实现这个接口。它的命名也必须遵循一定的规范,例如我们的MBean为Hello,则接口必须为HelloMBean。

dynamic MBean

必须实现javax.management.DynamicMBean接口,所有的属性,方法都在运行时定义

model MBean

与标准和动态MBean相比,你可以不用写MBean类,只需使用javax.management.modelmbean.RequiredModelMBean即可。RequiredModelMBean实现了ModelMBean接口,而ModelMBean扩展了DynamicMBean接口,因此与DynamicMBean相似,Model MBean的管理资源也是在运行时定义的。与DynamicMBean不同的是,DynamicMBean管理的资源一般定义在DynamicMBean中(运行时才决定管理那些资源),而model MBean管理的资源并不在MBean中,而是在外部(通常是一个类),只有在运行时,才通过set方法将其加入到model MBean中。

2、适配层:MbeanServer,提供对资源的注册和管理

3、接入层: 提供远程访问的入口

JMX最常见的场景是监控Java程序的基本信息和运行情况,任何Java程序都可以开启JMX,然后使用JConsole或Visual VM进行预览。

1.2 添加JMX功能

 1、wrapper程序添加JMX功能。

在wrapper.conf配置文件中添加如下配置:

local.jmx.port=39900

wrapper.java.additional.2=-Djava.rmi.server.hostname=192.168.1.75

wrapper.java.additional.3=-Dcom.sun.management.jmxremote.port=39900

wrapper.java.additional.4=-Dcom.sun.management.jmxremote.ssl=false

wrapper.java.additional.5=-Dcom.sun.management.jmxremote.authenticate=false

 2、一般java程序添加JMX功能。

    在java程序的命令后面指定如下指令

-Djava.rmi.server.hostname=127.0.0.1

-Dcom.sun.management.jmxremote.port=1000

-Dcom.sun.management.jmxremote.ssl=false

-Dcom.sun.management.jmxremote.authenticate=false

 

3、tomcat添加JMX功能。

 

CATALINA_OPTS="-Dcom.sun.management.jmxremote

-Djava.rmi.server.hostname=ip -Dcom.sun.management.jmxremote.port=9999 -Dcom.sun.management.jmxremote.ssl=false -Dcom.sun.management.jmxremote.authenticate=false"

 

 

2、Jconsole、jvisualvm工具使用

2.1 jconsole工具使用

1、远程连接进程

 

2、连接成功后可以观察概览、内存、线程、类、VM概要、MBean

 

3、  可以查看不同区的内存使用情况

 

2.2 jvisualvm工具使用

1、远程连接进程

 

2、登录成功可以查看概述、监视、线程、抽样器。

 

3、监视:CPU、内存、类、线程

 

 

4、通过抽样器可以做内存镜像

 

 

 

生成的文件在远程服务器上查看:

 

 

 

3、解析堆文件

3.1、使用jhat命令解析

jhat -J-mx10240m heapdump-1563861495449.hprof

   

   出现如下信息,表明读取镜像文件成功

 

3.2、页面展示

使用UI输入如下地址:http://192.168.1.75:7000/

 

 

 

 

通过页面可以查看:

(1)      显示出堆中所包含的所有的类

(2)       从根集能引用到的对象

(3)       显示平台包括的所有类的实例数量

(4)       堆实例的分布表

(5)       执行对象查询语句

 

 

 

4、JVM性能调优监控工具

jps、jstack、jmap、jhat、jstat、hprof

jmap这个命令执行,JVM会将整个heap的信息dump写入到一个文件,heap如果比较大的话,就会导致这个过程比较耗时,并且执行的过程中为了保证dump的信息是可靠的,所以会暂停应用, 线上系统慎用。

以上是关于Java内存监控方法的主要内容,如果未能解决你的问题,请参考以下文章

Java 内存监控之 jps命令

Java虚拟机性能监控与调优实战

性能监控之常见 Java Heap Dump 方法

Java 内存监控命令简介(零)

监控 Java 应用程序自己的内存使用情况

通过JConsoler监控Tomcat的JVM内存