常用的JVM参数,你现在就记好!
来源 | http://i7q.cn/50SRVt
前言
大家都知道,jvm在启动的时候,会执行默认的一些参数。一般情况下,这些设置的默认参数应对一些平常的项目也够用了。但是如果项目特别大了,需要增加一下堆内存的大小、或者是系统老是莫明的挂掉,想查看下gc日志来排查一下错误的原因,都需要咱们手动设置这些参数。
各个参数介绍
1.verbose:gc
表示,启动jvm的时候,输出jvm里面的gc信息。格式如下:
[Full GC 178K->99K(1984K), 0.0253877 secs]
解读 :Full GC 就表示执行了一次Full GC的操作,178K 和99K 就表示执行GC前内存容量和执行GC后的内存容量。1984K就表示内存总容量。后面那个是执行本次GC所消耗的时间,单位是秒。
2.-XX:+printGC
这个打印的GC信息跟上个一样,就不做介绍了。
3.-XX:+PrintGCDetails
打印GC的详细信息。格式如下:
–Heap
– def new generation total 13824K, used 11223K [0x27e80000, 0x28d80000, 0x28d80000)
– eden space 12288K, 91% used [0x27e80000, 0x28975f20, 0x28a80000)
– from space 1536K, 0% used [0x28a80000, 0x28a80000, 0x28c00000)
– to space 1536K, 0% used [0x28c00000, 0x28c00000, 0x28d80000)
– tenured generation total 5120K, used 0K [0x28d80000, 0x29280000, 0x34680000)
– the space 5120K, 0% used [0x28d80000, 0x28d80000, 0x28d80200, 0x29280000)
– compacting perm gen total 12288K, used 142K [0x34680000, 0x35280000, 0x38680000)
– the space 12288K, 1% used [0x34680000, 0x346a3a90, 0x346a3c00, 0x35280000)
– ro space 10240K, 44% used [0x38680000, 0x38af73f0, 0x38af7400, 0x39080000)
– rw space 12288K, 52% used [0x39080000, 0x396cdd28, 0x396cde00, 0x39c80000)
解读:new generation 就是堆内存里面的新生代。total的意思就是一共的,所以后面跟的就是新生代一共的内存大小。used也就是使用了多少内存大小。0x开头的那三个分别代表的是 底边界,当前边界,高边界。也就是新生代这片内存的起始点,当前使用到的地方和最大的内存地点。
eden space 这个通常被翻译成伊甸园区,是在新生代里面的,一些创建的对象都会先被放进这里。后面那个12288K就表示伊甸园区一共的内存大小,91% used,很明显,表示已经使用了百分之多少。后面的那个0x跟上一行的解释一样。
from space 和to space 是幸存者的两个区。也是属于新生代的。他两个区的大小必须是一样的。因为新生代的GC采用的是复制算法,每次只会用到一个幸存区,当一个幸存区满了的时候,把还是活的对象复制到另个幸存区,上个直接清空。这样做就不会产生内存碎片了。
tenured generation 就表示老年代。
compacting perm 表示永久代。由于这两个的格式跟前面我介绍的那个几乎一样,我就不必介绍了。
4.-XX:+PrintGCTimeStamps
打印GC发生的时间戳。格式如下:
289.556: [GC [PSYoungGen: 314113K->15937K(300928K)] 405513K->107901K(407680K), 0.0178568 secs] [Times: user=0.06 sys=0.00, real=0.01 secs]293.271: [GC [PSYoungGen: 300865K->6577K(310720K)] 392829K->108873K(417472K), 0.0176464 secs] [Times: user=0.06 sys=0.00, real=0.01 secs]
解读:289.556表示从jvm启动到发生垃圾回收所经历的的时间。GC表示这是新生代GC(Minor GC)。PSYoungGen表示新生代使用的是多线程垃圾回收器Parallel Scavenge。314113K->15937K(300928K)]这个跟上面那个GC格式一样,只不过,这个是表示的是新生代,幸存者区。后面那个是整个堆的大小,GC前和GC后的情况。Times这个显而易见,代表GC的所消耗的时间,用户垃圾回收的时间和系统消耗的时间和最终真实的消耗时间。
5.-X:loggc:log/gc.log
这个就表示,指定输出gc.log的文件位置。(我这里写的log/gc.log就表示在当前log的目录里,把GC日志写到叫gc.log的文件里。)
如果您正在学习Spring Boot,推荐一个连载多年还在继续更新的免费教程:http://blog.didispace.com/spring-boot-learning-2x/
6.-XX:+PrintHeapAtGC
表示每次GC后,都打印堆的信息。(这个打印的基本格式跟上面第二条的基本类似,我也就不比多说了。)
7.-XX:+TraceClassLoading
监控类的加载。格式如下:
•[Loaded java.lang.Object from shared objects file]
•[Loaded java.io.Serializable from shared objects file]
•[Loaded java.lang.Comparable from shared objects file]
•[Loaded java.lang.CharSequence from shared objects file]
•[Loaded java.lang.String from shared objects file]
•[Loaded java.lang.reflect.GenericDeclaration from shared objects file]
•[Loaded java.lang.reflect.Type from shared objects file]
使用这个参数就能很清楚的看到那些类被加载的情况了。
8.-XX:+PrintClassHistogram
跟踪参数。这个按下Ctrl+Break后,就会打印一下信息:
num #instances #bytes class name----------------------------------------------1: 890617 470266000 [B2: 890643 21375432 java.util.HashMap$Node3: 890608 14249728 java.lang.Long4: 13 8389712 [Ljava.util.HashMap$Node;5: 2062371680 [C6: 46341904 java.lang.Class
–分别显示:序号、实例数量、总大小、类型。
这里面那个类型,B和C的其实就是byte和char类型。
9.-Xmx -Xms
这个就表示设置堆内存的最大值和最小值。这个设置了最大值和最小值后,jvm启动后,并不会直接让堆内存就扩大到指定的最大数值。而是会先开辟指定的最小堆内存,如果经过数次GC后,还不能,满足程序的运行,才会逐渐的扩容堆的大小,但也不是直接扩大到最大内存。
10.-Xmn
设置新生代的内存大小。
如果您正在学习Spring Boot,推荐一个连载多年还在继续更新的免费教程:http://blog.didispace.com/spring-boot-learning-2x/
11.-XX:NewRatio
新生代和老年代的比例。比如:1:4,就是新生代占五分之一。
12.-XX:SurvivorRatio
设置两个Survivor区和eden区的比例。比如:2:8 ,就是一个Survivor区占十分之一。
13.-XX:+HeapDumpOnOutMemoryError
发生OOM时,导出堆的信息到文件。
14.-XX:+HeapDumpPath
表示,导出堆信息的文件路径。
15.-XX:OnOutOfMemoryError
当系统产生OOM时,执行一个指定的脚本,这个脚本可以是任意功能的。比如生成当前线程的dump文件,或者是发送邮件和重启系统。
16.-XX:PermSize -XX:MaxPermSize
设置永久区的内存大小和最大值。永久区内存用光也会导致OOM的发生。
17.-Xss
设置栈的大小。栈都是每个线程独有一个,所有一般都是几百k的大小。
往期推荐
Spring Boot如何实现在线预览?这个开源项目可以学习一下,支持99%常用文件!
Spring Security太复杂?试试这个轻量、强大、优雅的权限认证框架!
来!一起搭建个永久运行的个人服务器吧!
笑出腹肌的注释,都是被代码耽误的诗人!
快速搭建Java 17环境并玩转Record特性
技术交流群
最近有很多人问,有没有读者交流群,想知道怎么加入。加入方式很简单,有兴趣的同学,只需要点击下方卡片,回复“加群“,即可免费加入我们的高质量技术交流群!
点击阅读原文,送你免费Spring Boot教程!
常用的JVM参数,你现在就记好!相关推荐
- 后面的参数_常用的JVM参数,你现在就记好
作者:SimpleSmile_5177 来源:https://www.cnblogs.com/Simple-Object/p/10272326.html 前言 大家都知道,jvm在启动的时候,会执行默 ...
- 面试题(四)你工作中常用的jvm参数有哪些?
jvm常用参数: (1) -Xms.初始大小内存,默认为物理内存1/64.等价于 -XX:InitialHeapSize. (2) -Xmx.最大分配内存,默认为物理内存1/4.等价于 -XX:Max ...
- jvm 参数_6个提高性能的JVM参数
截止到2020年五月,JVM中仅仅只是关于垃圾回收和内存相关的参数就已经超过600个.如果算上其他方面的参数,JVM相关的总参数能轻松超过1000个.参数太多了,弄得人很懵逼.在这边文章中,我们只选取 ...
- seata之jvm参数解析
微信公众号:我其实目前没有耶 我是一个互联网公司的螺丝钉; 魔术师耿 JVM启动参数解析 疑问1 :生产环境上常用哪些JVM参数进行设置; 疑问2 :sh 启动jar 包并配置JVM参数样例怎么写; ...
- JVM参数太多?一网打尽常用JVM参数!
JVM提供的参数非常多,并且各种类型的参数能够提供不同的功能 理解JVM运行原理和熟悉常用JVM参数能够帮助我们更好的进行调优 本篇文章将介绍JVM参数的分类,以及GC日志.运行时内存区.OOM.垃圾 ...
- JVM常用调优参数 ——JVM篇
JVM常用性能调优参数详解 在学习完整个JVM内容后,其实目标不仅是学习了解整个JVM的基础知识,而是为了进行JVM性能调优做准备,所以以下的内容就是来说说JVM性能调优的知识. 一.性能调优 ...
- 常用的JVM调优参数总结汇总【随时查阅学习】
本文章参数根据后期用的参数会持续更新 --- (1)-Xms20M 表示设置JVM启动内存的最小值为20M,必须以M为单位 (2)-Xmx20M 表示设置JVM启动内存的最大值为20M,必须以M为单 ...
- JVM学习之路04--(常用JVM参数,内存分析)
目录 1.基于JDK命令行工具的监控 2.运行时JVM参数查看 3. jstat查看JVM统计信息 4. jamp+MAT(导出内存映像文件,MAT分析内存溢出) 1.基于JDK命令行工具的监控 1. ...
- java -jar 设置jvm参数_java8 常用JVM 参数修改
参考: https://www.cnblogs.com/jpfss/p/9753215.html 推荐阅读: 总结: 百万连接,百亿吞吐量服务的JVM性能调优实战 >>https:// ...
最新文章
- SAP事业部内部互供
- 自定义按键_雷柏VT300S号称吃鸡鼠标,能够自定义10个编程按键
- 常量中有换行符 是怎么回事?
- 从C语言到C++的进阶之面向对象、using与命名空间(篇四)
- php项目邮件连接无效,完美解决wordpress邮件链接无效的问题
- jQuery EasyUI教程之datagrid应用-1
- DxO发布Nik Collection 5插件,胶片颗粒更逼真
- c#winform panel空间拖动窗体 最小化 关闭 按钮 右下角弹窗
- 各种音视频编解码学习详解(7)--微软Windows Media系列
- 短信验证码登录的实现
- 抖音短视频吃鸡戏精野生脆脆如何上的热门
- Android连接逍遥模拟器
- 如何去掉图片上的水印 图片水印怎么去掉
- python pyqtgraph绘图库-绘制图形
- Postman安装与基本操作
- 【计算机研究与发展】一种基于区块链的泛用型数据隐私保护的安全多方计算协议——CCF A
- 致运营:你与年薪50万之间只隔了一个商业分析
- Web项目 - 登录注册业务逻辑
- 说一说我的java学习路途(记一个前端学习java日常)
- 虚拟网卡安装失败出现黄色三角Windows 仍在设置此设备的类配置。(代码56)