广告
返回顶部
首页 > 资讯 > 后端开发 > Python >JVM内存参数配置详解
  • 867
分享到

JVM内存参数配置详解

2024-04-02 19:04:59 867人浏览 八月长安

Python 官方文档:入门教程 => 点击学习

摘要

首先我们知道:JVM发生内存错误的类型 1、堆内存泄漏:OutOfMemory:Java heap space 此种内存泄漏,增加内存,只能暂时解决问题,并不能根治问题。必须要优化代

首先我们知道: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"

到此这篇关于JVM内存参数配置详解的文章就介绍到这了,更多相关JVM内存参数配置内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!

--结束END--

本文标题: JVM内存参数配置详解

本文链接: https://www.lsjlt.com/news/139839.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • JVM内存参数配置详解
    首先我们知道:JVM发生内存错误的类型 1、堆内存泄漏:OutOfMemory:Java heap space 此种内存泄漏,增加内存,只能暂时解决问题,并不能根治问题。必须要优化代...
    99+
    2022-11-13
  • tomcat内存配置及配置参数详解
    tomcat内存配置及配置参数详解 1、jvm内存管理机制: 1)堆(Heap)和非堆(Non-heap)内存 按照官方的说法:“Java 虚拟机具有一个堆,堆是运行时数据区域,所有类实例和数组的内存均从此处分配。堆是在 Java...
    99+
    2023-10-08
    tomcat Powered by 金山文档
  • jvm的内存参数说明和配置
    这篇文章主要介绍“jvm的内存参数说明和配置”,在日常操作中,相信很多人在jvm的内存参数说明和配置问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”jvm的内存参数说明和配置”的疑惑有所帮助!接下来,请跟着小编...
    99+
    2023-06-02
  • linux怎么设置jvm内存参数
    在 Linux 上设置 JVM 内存参数可以通过修改 JVM 的启动脚本或者设置环境变量来实现。以下是两种常见的方法:方法一:修改 ...
    99+
    2023-09-26
    linux jvm
  • linux如何设置jvm内存参数
    要设置JVM的内存参数,可以通过修改Java程序的启动脚本来实现。以下是在Linux上设置JVM内存参数的步骤:1. 打开Java程...
    99+
    2023-09-09
    linux jvm
  • jvm怎么设置堆内存参数
    要设置JVM的堆内存参数,需要在JVM启动时使用-Xmx和-Xms选项来指定最大堆内存和初始堆内存的大小。 -Xmx选项用于指定最大...
    99+
    2023-10-27
    jvm
  • 【JVM】JVM内存模型详解
    一、JVM是什么? JVM是Java Virtual Machine(Java虚拟机)的缩写,是通过在实际的计算机上仿真模拟各种计算机功能来实现的。由一套字节码指令集、一组寄存器、一个栈、一个垃圾回收...
    99+
    2023-09-16
    jvm java 面试
  • java jvm参数如何配置
    JVM(Java虚拟机)参数配置可以通过在命令行启动Java应用程序时使用“-XX”选项来完成。以下是常见的一些JVM参数配置:1....
    99+
    2023-08-30
    java
  • 解读Jvm的内存结构与GC及jvm参数调优
    目录一、JVM 内存结构1、类加载子系统2、方法区(method)3、堆(heap)4、栈(stack)5、本地方法栈6、pc寄存器(了解即可)7、执行引擎8、垃圾收集器二、堆&nd...
    99+
    2023-05-19
    Jvm内存结构 jvm参数调优 Jvm的内存结构与GC
  • jvm启动参数如何配置
    JVM启动参数可以通过命令行方式或者在启动脚本中进行配置。以下是一些常见的JVM启动参数配置示例:1. 设置堆内存大小:-Xms:设...
    99+
    2023-10-11
    jvm
  • JVM实用参数怎么配置
    JVM的实用参数可以通过在命令行中传递参数来进行配置。以下是一些常用的JVM实用参数的配置方法: 设置堆内存大小: -Xms:设...
    99+
    2023-10-24
    JVM
  • JVM入门之JVM内存结构内容详解
    一、java代码编译执行过程 源码编译:通过Java源码编译器将Java代码编译成JVM字节码(.class文件) 类加载:通过ClassLoader及其子类来完成...
    99+
    2022-11-12
  • 详谈jvm线程栈空间内存分配位置
    目录jvm线程栈空间内存分配位置JVM配置如下测试截的一些图片如下测试代码jvm栈大小设置1、栈内存大小设置2、递归调用jvm线程栈空间内存分配位置 jvm的线程栈申请的内存空间属于...
    99+
    2022-11-12
  • Java JVM内存区域详解
    目录程序计数器Java虚拟机栈方法/函数如何调用?堆总结原网页:JavaGuide JVM在执行Java程序过程中会把它管理的内存划分成若干个不同的数据区域。JDK1.8和之前的版本...
    99+
    2022-11-12
  • JVM的关键系统参数介绍和详细配置
    JVM(Java Virtual Machine)是一个虚拟机,它是Java程序的运行环境。在JVM的运行过程中,有一些关键的系统参...
    99+
    2023-08-29
    JVM
  • 详解DockerCompose配置文件参数
    目录1. image2. build3. command4.container_name5.depends_on6.dns7. tmpfs8. entrypoint9.env_fil...
    99+
    2022-11-13
  • MYSQL配置参数优化详解
    MySQL参数优化对于不同的网站,及其在线量,访问量,帖子数量,网络情况,以及机器硬件配置都有关系,优化不可能一次性完成,需要不断的观察以及调试,才有可能得到最佳的效果。 1)连接请求的变量 1、max_...
    99+
    2022-10-18
  • MySQL8.0新增配置参数详解
    MySQL8.0新增或改进了数据字典、原子DDL、安全和账户、资源管理、InnoDB增强、字符集支持、JSON增强、字段类型支持、优化器、通用表达式、窗口函数、正则表达式支持、内部临时表、日志、备份锁等特性...
    99+
    2022-10-18
  • linux怎么查看jvm的参数配置
    要查看JVM的参数配置,可以按照以下步骤进行:1. 打开终端或命令行界面。2. 运行`java -XX:+PrintFlagsFin...
    99+
    2023-09-09
    jvm linux
  • Redis 主从配置和参数详解
    安装redis下载redis wget http://download.redis.io/releases/redis-3.0.7.tar.gz解压redis tar -xvf ...
    99+
    2022-10-18
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作