百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 编程字典 > 正文

JVM调优常用参数(jvm调优实战简书)

toyiye 2024-08-17 00:20 9 浏览 0 评论

调优目的

JVM调优的目的是为了提高Java应用程序的性能和稳定性。通过优化JVM的配置和参数设置,可以减少内存占用、提高垃圾回收效率、优化线程管理等,从而提升应用程序的响应速度、降低内存泄漏的风险,并且减少应用程序的崩溃和停顿现象。调优可以根据具体的应用场景和需求进行,以达到最佳的性能和稳定性。

常见的一些行为方法:

  • 调整堆内存大小:通过调整-Xmx和-Xms参数来设置堆内存的最大和初始大小。合理地设置堆内存大小可以避免内存溢出和频繁的垃圾回收。
  • 调整垃圾回收器:JVM提供了多种垃圾回收器,如Serial、Parallel、CMS和G1等。根据应用程序的特点和需求,选择合适的垃圾回收器,并通过调整相关参数来优化垃圾回收性能。
  • 优化对象的创建和销毁:避免频繁创建和销毁大量的临时对象,可以减少垃圾回收的压力。可以使用对象池、缓存等技术来重用对象,提高性能。
  • 减少同步操作:过多的同步操作会导致线程竞争和阻塞,影响性能。可以使用无锁数据结构、并发集合类等技术来减少同步操作,提高并发性能。
  • 使用合适的数据结构和算法:选择合适的数据结构和算法可以提高程序的效率。例如,使用HashMap代替Hashtable、使用StringBuilder代替StringBuffer等。
  • 监控和分析JVM性能:使用JVM自带的工具(如jstat、jmap、jstack等)或第三方工具(如VisualVM、JProfiler等)来监控和分析JVM的性能瓶颈,找出优化的方向。

GC事件

JVM的垃圾回收GC事件可以分为以下几类:

  • Minor GC(新生代GC):针对新生代(Young Generation)的垃圾回收事件。在新生代中,通常采用复制算法进行垃圾回收,将存活的对象复制到另一个区域,同时回收无用的对象。Minor GC通常发生频率较高,但回收的对象数量较少。当JVM无法为新对象分配内存空间时总会触发Minor GC)
  • Major GC(老年代GC):针对老年代(Old Generation)的垃圾回收事件。在老年代中,通常采用标记-清除-整理算法进行垃圾回收,首先标记出存活的对象,然后清除无用的对象,最后进行内存整理。Major GC通常发生频率较低,但回收的对象数量较多。
  • Full GC(全局GC):对整个堆内存进行垃圾回收的事件。Full GC包括对新生代和老年代的垃圾回收,通常发生在新生代和老年代都满了的情况下,或者由于系统调用触发。Full GC的开销较大,会导致应用程序的停顿时间较长。
  • Concurrent GC(并发GC):在应用程序运行的同时进行垃圾回收的事件。并发GC的目标是尽量减少应用程序的停顿时间,通过与应用程序并发执行,提高系统的吞吐量。常见的并发GC算法有CMS(Concurrent Mark Sweep)和G1(Garbage First)。

常用参数总结

堆内存调优参数

  • -Xms:初始堆大小
  • -Xmx:最大堆大小
  • -Xmn:新生代大小
  • -Xss:线程堆栈大小,默认为1M
  • -XX:MaxPermSize=n:设置持久代大小
  • -XX:NewRatio:新生代和老年代的比例
  • -XX:SurvivorRatio:Eden区和Survivor区的比例

GC调优参数

  • -XX:+UseSerialGC:使用串行垃圾回收器
  • -XX:+UseParallelGC:使用并行垃圾回收器
  • -XX:+UseConcMarkSweepGC:使用CMS垃圾回收器
  • -XX:+UseG1GC:使用G1垃圾回收器
  • -XX:MaxGCPauseMillis:最大GC停顿时间
  • -XX:+UseAdaptiveSizePolicy:自适应GC策略

GC统计信息

  • -XX:+PrintGC:输出形式:
[GC 118250K->113543K(130112K), 0.0094143 secs]
[Full GC 121376K->10414K(130112K), 0.0650971 secs]
  • -XX:+PrintGCDetails:输出形式:
[GC [DefNew: 8614K->781K(9088K), 0.0123035 secs] 118250K->113543K(130112K), 0.0124633 secs]
[GC [DefNew: 8614K->8614K(9088K), 0.0000665 secs][Tenured: 112761K->10414K(121024K), 0.0433488 secs] 121376K->10414K(130112K), 0.0436268 secs]
  • -XX:+PrintGCTimeStamps:打印GC停顿耗时
  • -XX:+PrintGCApplicationStoppedTime:打印垃圾回收期间程序暂停的时间.
  • -XX:+PrintHeapAtGC:打印GC前后的详细堆栈信息
  • -Xloggc:filename:把相关日志信息记录到文件以便分析.

线程调优参数

  • -Xss:每个线程的堆栈大小
  • -XX:ParallelThreads:并行处理的线程数
  • -XX:+UseThreadPriorities:启用线程优先级
  • -XX:+UseCondCardMark:使用条件卡片标记

类加载调优参数

  • -XX:MaxPermSize:最大方法区大小
  • -XX:+CMSClassUnloadingEnabled:启用CMS类卸载
  • -XX:+UseCompressedOops:使用压缩对象指针

其他调优参数

  • -XX:+UseBiasedLocking:启用偏向锁
  • -XX:+OptimizeStringConcat:启用字符串拼接优化
  • -XX:MaxTenuringThreshold:对象晋升老年代的年龄阈值
  • -XX:CompileThreshold:JIT编译阈值
  • -XX:+PrintGCDetails:打印GC详细信息

示例配置

-XX:NewRatio=1:设置新生代和年老代的比值为2:1
-Xss:线程堆栈大小,默认为1M,调整为512K
-XX:+UseG1GC:使用G1做为GC收集器
-XX:MaxGCPauseMillis=n:设置并行收集最大暂停时间为20ms

相关推荐

# Python 3 # Python 3字典Dictionary(1)

Python3字典字典是另一种可变容器模型,且可存储任意类型对象。字典的每个键值(key=>value)对用冒号(:)分割,每个对之间用逗号(,)分割,整个字典包括在花括号({})中,格式如...

Python第八课:数据类型中的字典及其函数与方法

Python3字典字典是另一种可变容器模型,且可存储任意类型对象。字典的每个键值...

Python中字典详解(python 中字典)

字典是Python中使用键进行索引的重要数据结构。它们是无序的项序列(键值对),这意味着顺序不被保留。键是不可变的。与列表一样,字典的值可以保存异构数据,即整数、浮点、字符串、NaN、布尔值、列表、数...

Python3.9又更新了:dict内置新功能,正式版十月见面

机器之心报道参与:一鸣、JaminPython3.8的热乎劲还没过去,Python就又双叒叕要更新了。近日,3.9版本的第四个alpha版已经开源。从文档中,我们可以看到官方透露的对dic...

Python3 基本数据类型详解(python三种基本数据类型)

文章来源:加米谷大数据Python中的变量不需要声明。每个变量在使用前都必须赋值,变量赋值以后该变量才会被创建。在Python中,变量就是变量,它没有类型,我们所说的"类型"是变...

一文掌握Python的字典(python字典用法大全)

字典是Python中最强大、最灵活的内置数据结构之一。它们允许存储键值对,从而实现高效的数据检索、操作和组织。本文深入探讨了字典,涵盖了它们的创建、操作和高级用法,以帮助中级Python开发...

超级完整|Python字典详解(python字典的方法或操作)

一、字典概述01字典的格式Python字典是一种可变容器模型,且可存储任意类型对象,如字符串、数字、元组等其他容器模型。字典的每个键值key=>value对用冒号:分割,每个对之间用逗号,...

Python3.9版本新特性:字典合并操作的详细解读

处于测试阶段的Python3.9版本中有一个新特性:我们在使用Python字典时,将能够编写出更可读、更紧凑的代码啦!Python版本你现在使用哪种版本的Python?3.7分?3.5分?还是2.7...

python 自学,字典3(一些例子)(python字典有哪些基本操作)

例子11;如何批量复制字典里的内容2;如何批量修改字典的内容3;如何批量修改字典里某些指定的内容...

Python3.9中的字典合并和更新,几乎影响了所有Python程序员

全文共2837字,预计学习时长9分钟Python3.9正在积极开发,并计划于今年10月发布。2月26日,开发团队发布了alpha4版本。该版本引入了新的合并(|)和更新(|=)运算符,这个新特性几乎...

Python3大字典:《Python3自学速查手册.pdf》限时下载中

最近有人会想了,2022了,想学Python晚不晚,学习python有前途吗?IT行业行业薪资高,发展前景好,是很多求职群里严重的香饽饽,而要进入这个高薪行业,也不是那么轻而易举的,拿信工专业的大学生...

python学习——字典(python字典基本操作)

字典Python的字典数据类型是基于hash散列算法实现的,采用键值对(key:value)的形式,根据key的值计算value的地址,具有非常快的查取和插入速度。但它是无序的,包含的元素个数不限,值...

324页清华教授撰写【Python 3 菜鸟查询手册】火了,小白入门字典

如何入门学习python...

Python3.9中的字典合并和更新,了解一下

全文共2837字,预计学习时长9分钟Python3.9正在积极开发,并计划于今年10月发布。2月26日,开发团队发布了alpha4版本。该版本引入了新的合并(|)和更新(|=)运算符,这个新特性几乎...

python3基础之字典(python中字典的基本操作)

字典和列表一样,也是python内置的一种数据结构。字典的结构如下图:列表用中括号[]把元素包起来,而字典是用大括号{}把元素包起来,只不过字典的每一个元素都包含键和值两部分。键和值是一一对应的...

取消回复欢迎 发表评论:

请填写验证码