JVM内存参数配置详解
作者:QH.Thomas 发布时间:2022-05-20 19:17:57
首先我们知道:JVM发生内存错误的类型
1、堆内存泄漏:OutOfMemory:Java heap space
此种内存泄漏,增加内存,只能暂时解决问题,并不能根治问题。必须要优化代码,一定是代码的问题:排查堆中的大量对象,就会发现,这些对象都被引用,对象不能及时被回收,导致超出了堆的设定最大内存。
2、老年代内存泄漏:OutOfMemoryError:PermGen space
类名、访问修饰符、字段描述、方法描述等,所占空间大于永久代最大值,就会出现,一般都是初始化内存的时候,空间太小,解决办法是扩大空间
3、栈内存泄漏:StackOverflowError
代码执行时,代码进栈,此刻如果栈的内存不足以容纳要进栈的代码的大小空间,那么久会报该错误。可以通过设置栈的空间大小。一般通过:-Xss设置线程的大小来解决。比如:-Xss256m
下面进入如何检测jvm内存情况的实际操作:
1、监控JVM的GC情况:
jstat -gcutil pid 2000 20
(只需要看O,如果达到100%,并且长期处于100%,则代表老年代内存不足)
pid:服务进程的pid,可通过:ps -ef | grep java
来查看java的服务进程pid
2000:每隔多少秒进行监控一次。这里是2秒
20: 总共获取20次
E:eden区
O:老年代
P:永久代
YGC:新生代的GC次数
YGCT:当前统计的YGC一共花费的时间(毫秒)
FGC:fullGC老年代的GC次数
FGCT:当前统计的FGC一共花费的时间(毫秒)
GCT:YGC+FGC
2、查看jvm配置信息
jmap -head pid //可以看到java进程的堆的配置信息,各区的空间大小和配置信息
3、查看jvm中类和对象的占用情况
jmap -histo 5279 | head -20 //查看jvm中各个类的实例数、占用内存数量以及类的全名
4、上面使我们的基本命令使用,那么我们怎么预测或者说内存泄漏会有什么征兆?
1、tps出现大幅波动,并慢慢降低,甚至降为0,响应时间随之波动,慢慢升高
2、通过jstat命令看到,Jvm中Old区不断增加,FullGC非常频繁,对应的FullGC消耗的时间也不断增加
3、通过jconsole/jvisualvm可以看到,堆内存曲线不断上升,接近上限时,变成一条直线
4、日志报错java.lang.OutOfMemoryError: Java heap space
5、内存泄露怎么定位?
(1、确定征兆: 现象方面,Java进程抛出OOM异常,分析属于那种异常,是正常的内存资源耗尽还是内存泄漏。
(2、监控jvm的GC情况:jstat -gcutil pid 1000 100 (只需要看O,如果达到100%,并且长期处于100%,则代表老年代内存不足) 如果有大量的FGC就要查询是否有内存泄漏的问题了
(3、通过jmap命令:jmap -histo pid | head -20,查看当前堆内存中实例数和占用内存最多的前20个对象
(4、通过jvisualvm分析定位:进行远程堆dump,然后把dump文件下载下来,用jvisualvm打开进行分析,可以看到更直观的jvm中对象的信息
6、下面是进行最后的JVM参数调优:
vm常用参数
---------------------------------------
堆内存 = 年轻代+老年代
年轻代 = Eden+Survivor
Survivor = From Space+To Space
---------------------------------------
年轻代 = Eden+From Space+To Space
堆内存=Eden+From Space+To Space+老年代
====================================
-Xms2048m:初始堆大小,建议<物理内存的1/4,默认值为物理内存的1/64
-Xmx2048m:最大堆大小,建议与-Xms保持一致,默认值为物理内存的1/4
-Xmn512m:新生代大小,建议不超过堆内存的1/2-Xss256k,线程堆栈大小,建议256k
-XX:PermSize=256m:永久代初始值,默认值为物理内存的1/64
-XX:MaxPermSize=256m:永久代最大值,默认值为物理内存的1/4
-XX:SurvivorRatio=8:年轻带中Eden区和Survivor区的比例,默认为8:1,即Eden(8),FromSpace(1),ToSpace(1)
-XX:MaxTenuringThreshold=15:晋升到老年代的对象年龄,每个对象坚持过一次MinorGC后对象年龄+1,默认值是15,年龄超过15进入到老年代,该参数在串行GC时有效-
XX:PretenureSizeThreshold=3145728:单位字节,只对Serial和ParNew两款收集器有效,新生代采用Parallel Scavenge GC时无效,大于这个值的对象直接在老年代进行分配
7、参数设置在哪里?
一般来说,一个服务器可能有多个java服务进行,对吧?是很多服务器都会有这种情况,那么问题来了,那我要是统一在jvm配置文件修改jvm参数,那么岂不是所有服务都是这个参数?所以有没有其他办法?
有!!!!那就是在java进程启动命令设置。
nohup java ${JAVA_OPT} -jar xxx.jar 2>&1&
JAVA_OPT的参数:里面参数自行看要设置什么,以及具体的参数值
JAVA_OPT="-server -Xms256m -Xmx256m -Xmn512m -XX:MetaspaceSize=64m -XX:MaxMatespaceSize=256m"
来源:https://www.cnblogs.com/qq1141100952com/p/15916463.html


猜你喜欢
- using System.Drawing;using System.Drawing.Imaging;using System.IO;usin
- 什么是sam 转换Single Abstract Method 实际上这是java8中提出的概念,你就把他理解为是 一个方法的接口 的就可以
- 之前从他人的博文,还有一些书籍中了解到 常量是放在常量池 中,细节的内容无从得知,总觉得面前的东西是一个几乎完全的黑盒,总是觉得不舒服,于是
- 这种结果的原因在于,Random()函数的默认种子是时间,但在循环中产生随机数时,由于运算速度太快,用做种子的时间是相同的(毫秒级),因此产
- 认识数组数组的定义数组是相同类型数据的有序集合。数组描述的是相同类型的若干个数据,按照一定的先后次序排列组合而成。其中,每一个数据称作一个元
- 赛马下周一就要去做java实验了,还记得上一次实验还有一个程序没写完,匆匆交了实验报告的半成品(希望老师没发现www)。为了下周一能有更充裕
- 最近,在使用spring cloud框架时,发现feign也能实现三方请求,而且实现很简单,请求接口的结构很清晰,便果断学习一波。记录一下。
- 哈希 Hash 算法介绍哈希算法也叫散列算法, 不过英文单词都是 Hash, 简单一句话概括, 就是可以把任意长度的输入信息通过算法变换成固
- 效果图,每隔1秒,变换一下时间 xml: <RelativeLayout xmlns:android="http
- 如果运行react-native android项目出现如下错误:解决办法如下:一、执行adb devices,判断adb有没有断,二、如果
- 一、strcmp函数适用对象char*类型字符串函数介绍strcmp函数是cstring库中的函数,包含在string.h头文件中用法str
- android studio 版本不同连接手机方式有细微的不同,主要方式相似。介绍主要分手机和电脑两部分介绍。一、手机部分1、手机端下载一个
- 旋转扭曲特效是指在一个圆形区域内扭曲所渲染的图像,其他像素的旋转程度随着距离的变化而变化。具体可以通过修改Shader来实现。原始图片扭曲图
- 本文实例讲述了C#实现DataSet内数据转化为Excel和Word文件的通用类。分享给大家供大家参考,具体如下:前不久因为项目的需要写的一
- 介绍Java状态模式(State Pattern)是一种面向对象的设计模式,它将对象的状态封装成独立的状态对象,并将对象的行为与状态对象解耦
- 本文为大家分享了android倒计时控件,供大家参考,具体代码如下/* * Copyright (C) 2012 The * Project
- Java实现Dijkstra输出指定起点到终点的最短路径前言:最近在公司参加了一个比赛,其中涉及的一个问题,可以简化成如是描述:一个二维矩阵
- Java判断一个字符串是否有中文一般情况是利用Unicode编码(CJK统一汉字的编码区间:0x4e00–0x9fbb)的正则来做判断,但是
- 实现的功能:默认情况下将扫描整个项目的文件可以使用@ComponentScan注解配置扫描路径只将被@Component注解修饰的类装载到容
- 一个线程如何知道另一线程已经结束?Thread类提供了回答此问题的方法。有两种方法可以判定一个线程是否结束。第一,可以在线程中调用isAli