首页 技术 正文
技术 2022年11月14日
0 收藏 743 点赞 5,091 浏览 3920 个字

学过java的人都知道,jvm是解释运行java的,java能够作为跨平台语言,也是因为jvm的存在,合理的使用jvm内存可以帮助程序很好的运行。那么,怎么查看jvm的内存使用情况呢,下面本文介绍一下。可以同步参看链接:https://www.vxzsk.com/734.html

方式一

java程序查看

使用java代码也是可以查看jvm内存使用情况的,如果你经验比较丰富的话,应该是知道的,那就是使用Runtime,Runtime对java的运行环境进行的封装,可以得到jvm的状态信息,使用Runtime.getRuntime()就可以得到Runtime的引用。使用Runtime的maxMemory(),totalMemory(),freeMemory()几个方法就可以得到jvm的内存使用情况maxMemory是jvm可以从操作系统可以获得最大内存,totalMemory是jvm已经分配到的内存大小,freeMemory是所分配内存的剩余大小,可以通过代码运行查看。

package com.asd.reserve.controller;/**
* @author zs
* @date 2019/12/23 11:23
*/
public class Testszs { public static void main(String[] args) {
Runtime run = Runtime.getRuntime(); long maxMemory = Runtime.getRuntime().maxMemory();
long totalMemory = Runtime.getRuntime().totalMemory();
long freeMemory = Runtime.getRuntime().freeMemory();
long usableMemony = maxMemory - totalMemory + freeMemory;
System.out.println("可以获得最大内存是:"+ maxMemory/1024/1024 + "M");
System.out.println("已分配到的内存大小是:"+ totalMemory/1024/1024 + "M");
System.out.println("所分配内存的剩余大小是:"+ freeMemory/1024/1024 + "M");
System.out.println("最大可用内存大小是:"+ usableMemony/1024/1024 + "M"); }
}

方式二

上面说了一下通过java代码查看jvm内存的使用情况的方法,下面说一下使用jvm工具查看的方法,在jdk的bin目录下,是有很多命令行工具,这些命令行工具都是可以帮助分析java的运行情况的。下面介绍两种方式:

1、进入jdk的bin目录,shift+右键 在bin目录打开命令行窗口,通过jps查看服务的pid,选择要监控的jvm,执行jamp -heap pid

如何查看JVM的内存

如何查看JVM的内存

2、使用jdk自带的jconcole就会出现一个可视化的工具框,就可以查看堆内存使用情况,cpu占有率。直接运行jconcole.exe,如下图所示:

如何查看JVM的内存

JVM参数类型

1、 标准参数(-)

所有的JVM实现都必须实现这些参数的功能,而且向后兼容。例如:-verbose:class(输出jvm载入类的相关信息,当jvm报告说找不到类或者类冲突时可此进行诊断);-verbose:gc(输出每次GC的相关情况);-verbose:jni(输出native方法调用的相关情况,一般用于诊断jni调用错误信息)。
2、 非标准参数(-X)
默认jvm实现这些参数的功能,但是并不保证所有jvm实现都满足,且不保证向后兼容。例如:-Xms512m;-Xmx512m;-Xmn200m;-Xss128k;-Xloggc:file(与-verbose:gc功能类似,只是将每次GC事件的相关情况记录到一个文件中,文件的位置最好在本地,以避免网络的潜在问题。若与verbose命令同时出现在命令行中,则以-Xloggc为准)。
3、 非Stable参数(-XX)
此类参数各个jvm实现会有所不同,将来可能会随时取消,需要慎重使用。例如:-XX:PermSize=64m;-XX:MaxPermSize=512m。

2.2 标准参数
1、 -help
2、-server -client
3、 -version -showversion
4、-cp -classpath

2.3 X参数
非标准化参数
-Xint : 解释执行
-Xcomp:第一次使用就编译成本地代码
-Xmixed: 混合模式,JVM自己来决定是否编译成本地代码

2.4 XX参数
非标准化参数
相对不稳定
主要用于JVM调优和Debug
XX参数分类:
1、Boolean类型
格式: -XX:[+-]<name> 表示启用或者禁用name属性
比如: -XX:+UseConcMarkSweepGC
    -XX:UseG1GC

2、非Boolean类型
格式: -XX:<name>=<value> 表示name属性的值是value
比如:-XX:MaxGCPauseMillis=500
   XX:GCTimeRatio=19

3、 -Xmx -Xms
不是X参数,而是XX参数
-Xms等价于-XX:InitialHeapSize
-Xmx等价于-XX:MaxHeapSize

3 JVM参数查看
3.1 查看JVM运行时参数
-XX:+PrintFlagsInitial
-XX:+PrintFlagsFinal
-XX:+UnlockExperimentalVMOptions //解锁实验参数
-XX:+UnlockDiagnosticVMOptions //解锁诊断参数
-XX:+PrintCommandLineFlags //打印命令行参数

-XX:+UseSerialGC,虚拟机运行在Client模式下的默认值,Serial+Serial Old。
-XX:+UseParallelGC,虚拟机运行在Server模式下的默认值,Parallel Scavenge+Serial Old(PS Mark Sweep)。
-XX:+UseParNewGC,ParNew+Serial Old,在JDK1.8被废弃,在JDK1.7还可以使用。
-XX:+UseParallelOldGC,Parallel Scavenge+Parallel Old。
-XX:+UseConcMarkSweepGC,ParNew+CMS+Serial Old。
-XX:+UseG1GC,G1+G1,只支持JDK1.7 14update以上

java -XX:+PrintCommandLineFlags -version //查看jvm默认的垃圾回收器

3.2 参数使用
java -XX:+PrintFlagsInitial -version > PrintFlagsInitial.txt //这个命令的值很多,保存到文件中
java -XX:+PrintFlagsFinal -version > PrintFlagsFinal.txt

3.3 jps 查看java进程
jps //查看java进程
jps -l //显示完整的类名

3.4 查看正在运行的JVM参数

jinfo -flags pid //查看设置过值的参数
jinfo -flag InitialHeapSize pid //查看初始堆内存
jinfo -flag MaxHeapSize pid //查看最大堆内存
jinfo -flag PermSize pid //查看初始分配的非堆内存
jinfo -flag MaxPermSize pid //查看最大允许分配的非堆内存
jinfo -flag NewSize pid //查看年轻代初始内存
jinfo -flag MaxNewSize pid //查看年轻代最大内存
jinfo -flag NewRatio pid //查看年轻代与年老代的比值
jinfo -flag SurvivorRatio pid //查看年轻代中Eden区与Survivor区的比值
jinfo -flag MaxTenuringThreshold pid //查看对象如果在Survivor区移动了N次还没有被垃圾回收就进入年老代

jinfo -flag UseSerialGC pid //查看串行收集器
jinfo -flag UseParallelGC pid //查看并行收集器
jinfo -flag UseParNewGC pid //查看并行收集器
jinfo -flag UseParallelOldGC pid //查看并行收集器
jinfo -flag UseConcMarkSweepGC pid //查看CMS回收器
jinfo -flag UseG1GC pid //查看G1回收器
jinfo -flag PrintGCDetails pid //查看是否打印GC日志

4 JVM常用工具
4.1 jps
jps //查看java进程
jps -l //显示完整的类名
jmap -heap pid > 1.txt //查看JVM内存配置,参数较多,保存到文件
4.2 jinfo
jinfo -flag InitialHeapSize pid //查看初始堆内存
jinfo -flag MaxHeapSize pid //查看最大堆内存
jinfo -flag PermSize pid //查看初始分配的非堆内存
jinfo -flag MaxPermSize pid //查看最大允许分配的非堆内存
jinfo -flags pid //查看设置过值的参数
jinfo -flag UseConcMarkSweepGC pid //查看垃圾回收器
jinfo -flag UseG1GC pid //查看垃圾回收器
jinfo -flag UseParallelGC pid //查看垃圾回收器

上一篇: SimpliciTI APP
下一篇: Object中的方法
相关推荐
python开发_常用的python模块及安装方法
adodb:我们领导推荐的数据库连接组件bsddb3:BerkeleyDB的连接组件Cheetah-1.0:我比较喜欢这个版本的cheeta…
日期:2022-11-24 点赞:878 阅读:9,000
Educational Codeforces Round 11 C. Hard Process 二分
C. Hard Process题目连接:http://www.codeforces.com/contest/660/problem/CDes…
日期:2022-11-24 点赞:807 阅读:5,512
下载Ubuntn 17.04 内核源代码
zengkefu@server1:/usr/src$ uname -aLinux server1 4.10.0-19-generic #21…
日期:2022-11-24 点赞:569 阅读:6,358
可用Active Desktop Calendar V7.86 注册码序列号
可用Active Desktop Calendar V7.86 注册码序列号Name: www.greendown.cn Code: &nb…
日期:2022-11-24 点赞:733 阅读:6,141
Android调用系统相机、自定义相机、处理大图片
Android调用系统相机和自定义相机实例本博文主要是介绍了android上使用相机进行拍照并显示的两种方式,并且由于涉及到要把拍到的照片显…
日期:2022-11-24 点赞:512 阅读:7,771
Struts的使用
一、Struts2的获取  Struts的官方网站为:http://struts.apache.org/  下载完Struts2的jar包,…
日期:2022-11-24 点赞:671 阅读:4,849