JVM参数与性能优化

news/2025/4/22 2:07:03

在很多地方都会用到 JVM 参数,比如你运行 ant check-style,跑挂了,抛了个 OutOfMemory 错误。这时你上网搜索,他们会告诉你,应该修改 ANT_OPTS 环境变量,加上“-Xmx512m”。

再比如 JBoss 或 tomcat 都有启动脚本(startup.bat等),里面也用到 JVM 参数。还有 Eclipse 的 eclipse.ini 中也可以加入 JVM 参数。灵活使用这些 JVM 参数可以使我们的 Java 程序获得更好的性能。


=== 常用参数 ===

-server
  一定要作为第一个参数,会使JVM启动速度变慢,但会显著提升JVM性能

-Xms64m
  设置初始 Heap 大小,使用的最小内存

-Xmx1024m
  设置最大 Heap 大小

-Xss256k
  设置每个线程的 Stack 大小

-XX:MaxPermSize=128M
  设置最大永久区大小,永久保存区用于存放Class信息和元信息


=== GC(垃圾回收)参数 ===

Sun HotSpot JVM 通常使用的 GC 算法是分代回收。即把对象按生命周期不同分为年轻代和年老代。新的对象会先生成在Young Area,在几次 GC 以后,如果没有收集到,就会逐渐升级到Tenured Area。

Sun JVM 默认的回收器称为 serial collector ,即串行回收,我们也可以使用多线程并发回收来提高效率。需要注意的是,在单核的机器上,使用默认的回收器可能会更好。

-XX:+UseParNewGC
  为年轻代对象使用并发回收,会缩短年轻代对象的回收时间

-XX:+UseConcMarkSweepGC
  为年老代使用并发回收

-XX:+UseParallelGC
  该收集器和 UseConcMarkSweepGC 是互相排斥的,为新生代使用并行清除,年老代使用单线程Mark-Sweep-Compact的垃圾收集器。


=== 其他参数 ===

-XX:CompileThreshold=100
  该值表示编译之前必须调用方法的次数。HotSpot JVM 使用 JIT(Just-In-Time Compilation, http://en.wikipedia.org/wiki/Just-in-time_compilation) 技术将字节码编译成本地码,默认值为1000,即一个方法被调用了 1000 次之后 JVM 会编译它。降低这个值可能会使程序的性能得到提升,但会使启动速度变慢。

-XX:+DoEscapeAnalysis
  启用逃逸分析,这个选项只能用于 Java 1.6。原理参见:http://kenwublog.com/jvm-optimization-escape-analysis


=== JVM参数的设置 ===

可以直接在java命令后面附加,比如:java -Xmx512m -XX:+UseParNewGC Test

还可以在环境变量中设置,如 JAVA_OPTS 和 ANT_OPTS 。还可以在eclipse.ini中设置,需要写在 -vmargs 一行的后面


=== 参考资料 ===

 * Java 6 JVM参数选项大全(中文版):http://kenwublog.com/docs/java6-jvm-options-chinese-edition.htm
 * Garbage Collection - Frequently Asked Questions:http://java.sun.com/docs/hotspot/gc1.4.2/faq.html
 * 调整 JVM 开关以获得最佳性能:http://gceclub.sun.com.cn/NetBeans/tutorials/tuning/index.html


https://dhexx.cn/news/show-1106874.html

相关文章

【AI-CPS】【智能制造】智能装备 ── 强化工业基础能力

苗圩“中国制造2025”要抓住智能装备和智能产品的研发和生产,通过高档数字机床、工业机器人等智能制造装备和智能化生产建材,加快可穿戴产品、智能家电、服务机器人等智能化产品的研发和产业化,大力推进制造过程的智能化。——工业和信息化部…

组件、插件、模块、子应用、库、框架等概念辨析(*)

组件、插件、模块、子应用、库、框架等概念辨析 网上有许多讲组件化、模块化等概念的文章,但大家一般都是将这两个概念混为一谈的,并没有加以区分。而且实际上许多人对于组件、插件、模块、子应用等概念的区别也不甚明了,甚至于许多博客文章…

Linux用户登录查看命令总结 - w,who,last,lastlog

1. 查看登录用户信息 who -H命令输出 NAME: 用户名 LINE: 登录终端 TIME: 登录时间 (登录来源IP地址)实例 [vagrant~] ]$who -H NAME LINE TIME COMMENT vagrant pts/2 2018-04-23 00:40 (10.0.2.2)2. 查看登录用户的信息及他们的行为 w [用户…

loadrunner java协议脚本要点

常见问题 1. Error: Thread Context: Call to service of the driver failed, reason - thread context wasnt initialized on this thread.[MsgId: MERR-10176] 这个问题网上很多解答,感觉诱发的原因不一,我的问题是当时代码里有:     package lr.test; 2. 关于loadrunner…

Selenium中文手册

Selenium中文手册一 Commands (命令)Action 对当前状态进行操作失败时,停止测试 Assertion校验是否有产生正确的值 Element Locators指定HTML中的某元素 Patterns用于模式匹配 1. Element Locators (元素定位器)ididid locator 指定HTML中的唯一id的元素 nam…

【财富空间】10张图分清工作和事业的区别!

有人说为别人打工叫工作,为自己做事叫事业。这里指的不是被雇佣和自己开公司的区别,而是从事一份工作时的心态和态度差异。下面,我们用十张图来告诉你二者的真正区别。1.短期VS长期打工:短期心态,重视眼前利益&#xf…

Scala的泛型

我们在这文章将要学习Scala的最后一个特性是泛型。Java程序员们可能最近才知道这个东西,因为这个特性是在Java1.5中才被加入的。泛型是一种可以让你使用类型参数的设施。例如当一个程序员正在实现一个链表时,将不得不面对诸如如何决定链表中节点保存数据…

如何为HTML5 Video载入WebVTT字幕

今天无意看到了一篇关于在H5 video插入字幕的文章,简单做个总结。 前言 网页中使用H5 video播放视频文件,一般而言不外乎是: 字幕嵌在影片里字幕档另外挂上第 1 种方法很单纯,字幕就是影片的一部份,所以只要能把影片播…

ROS开发环境搭建(Ubuntu22.04、ROS2 Humble)

1.ROS环境搭建简介 官方指导地址:http://docs.ros.org/ 笔者是2023年4月初开始学习ROS,本文为当时的过程记录。其他情况不在此文中表述。 上图是官方文档首页,秉持“要学就学新的”和“接受官方推荐” 原则。故选择Humble版本。 在安装指导…

Web前端-HTTP Cache-control

HTTP协议分别在 1.0 / 1.1 两个时代推出了 Expires / Cache-control 两种cache策略,这里我们无需了解全部的细节,无需记住整个RFC内容,但是当我们需要使用HTTP cache策略时,我们需要注意以下细节:Expires 是HTTP 1.0 那个时代的东…