JVM有哪些参数以及如何使用

news/2024/10/11 5:20:56/

JVM(Java虚拟机)参数用于调整和优化Java应用程序的性能和行为。这些参数主要分为标准参数、非标准参数(以-X开头)和高级参数(以-XX开头)。以下是一些常见的JVM参数及其使用方法:

标准参数

  • -server:启动JVM时使用服务器模式,适用于生产环境,具有更好的性能和内存管理效率。
  • -client:启动JVM时使用客户端模式,适用于桌面应用程序或开发测试环境,启动速度较快。
  • -verbose:class:输出JVM载入类的相关信息,有助于诊断类加载问题。
  • -verbose:gc:输出每次垃圾回收(GC)的相关情况,有助于了解JVM的内存管理行为。
  • -verbose:jni:输出本地方法调用的相关情况,有助于诊断JNI调用错误信息。
  • -classpath 或 -cp:指定类路径,可以包括多个目录和JAR文件。
  • -version 或 -showversion:显示JVM版本信息。

非标准参数(-X参数)

  • -Xms:设置JVM初始堆内存大小,单位为MB或G。例如,-Xms512m表示设置初始堆内存为512MB。
  • -Xmx:设置JVM最大堆内存大小,单位为MB或G。例如,-Xmx2g表示设置最大堆内存为2GB。建议在线上生产环境中,将-Xms和-Xmx设置为相同的值,以避免内存抖动。
  • -Xmn:设置新生代内存大小,包括Eden区和两个Survivor区的总和。这个参数会影响JVM的内存分配和垃圾回收行为。
  • -Xss:设置线程堆栈大小,单位为KB。例如,-Xss128k表示设置线程堆栈大小为128KB。
  • -Xloggc::将每次GC事件的相关情况记录到一个文件中,有助于分析JVM的内存管理行为。
  • -Xint:仅解释模式执行,JVM不会进行即时编译。
  • -Xmixed:混合模式执行,默认模式,JVM会进行即时编译和解释执行。

高级参数(-XX参数)

  • -XX:NewSize=:设置新生代对象生成时占用内存的默认值。
  • -XX:MaxNewSize=:设置新生成对象能占用内存的最大值。
  • -XX:PermSize=:设置永久代(PermGen)的初始大小,单位为MB。在JDK 8及更高版本中,永久代被元空间(Metaspace)替代。
  • -XX:MaxPermSize=:设置永久代(PermGen)的最大大小,单位为MB。在JDK 8及更高版本中,此参数不再使用。
  • -XX:MetaspaceSize=:设置元空间的初始大小,单位为MB。元空间用于存储类的元数据。
  • -XX:NewRatio=:设置新生代与老生代的内存容量比例。例如,-XX:NewRatio=4表示新生代与老生代的比例为1:4。
  • -XX:SurvivorRatio=:设置Eden区与Survivor区的容量比值。例如,-XX:SurvivorRatio=8表示Eden区与两个Survivor区的比例为8:1:1。
  • -XX:+HeapDumpOnOutOfMemoryError:在JVM遇到内存溢出异常(OOM)时生成堆转储文件,有助于分析内存泄漏问题。
  • -XX:HeapDumpPath= :指定导出堆信息时的路径或文件名。
  • -XX:+UseConcMarkSweepGC:启用CMS垃圾收集器,适用于对响应时间要求较高的应用场景。
  • -XX:+UseG1GC:启用G1垃圾收集器,适用于需要处理大量内存和减少停顿时间的应用场景。
  • -XX:+PrintGC:在控制台上打印出GC信息。
  • -XX:+PrintGCDetails:在控制台上打印出详细的GC信息,包括各个内存区域的分配和回收情况。
  • -XX:+PrintGCTimeStamps:打印每次GC的时间戳,有助于了解GC的执行时间。
  • -XX:MaxGCPauseMillis=:设置最大GC暂停时间的目标(以毫秒为单位),JVM会尝试在满足该目标的前提下进行垃圾回收。

使用方法

  1. 在开发工具中设置:如IDEA、Eclipse等IDE,可以在运行配置中设置JVM参数。
  2. 在命令行中运行JAR包时设置:使用java命令运行JAR包时,可以在命令后添加JVM参数。例如:
java -Xmx1024m -Xms1024m -jar xxx.jar
  1. 在Tomcat容器中设置:在Tomcat的启动脚本(如catalina.sh)中设置JAVA_OPTS环境变量,以指定JVM参数。例如:
JAVA_OPTS="-server -Xms8g -Xmx8g -XX:NewRatio=4 -XX:SurvivorRatio=8 -XX:+UseConcMarkSweepGC -XX:ParallelGCThreads=8 -XX:+HeapDumpOnOutOfMemoryError -XX:HeapDumpPath=/usr/local/gclogs/dump/heap.hprof -XX:+PrintGCDetails -XX:+PrintGCDateStamps -Xloggc:/usr/local/gclogs/gc.log -XX:+DisableExplicitGC"

了解并掌握这些JVM参数的使用方法,有助于优化Java应用程序的性能和内存管理行为。


http://www.ppmy.cn/news/1537280.html

相关文章

基于单片机的山林远程环境监测仪设计

本设计基于单片机的智能化的远程山林环境检测仪,该检测仪由硬件系统和软件系统构成。电源管理模块给整个硬件系统提供工作所需电源,系统可完成山林环境有关的温度、湿度、火焰和海拔高度的采集,并且可通过与按键设置阈值作对比判断危险情况&a…

数学基础 -- 微积分之链式求导法则

链式求导法则 链式求导法则(Chain Rule)是微积分中非常重要的法则,用于计算复合函数的导数。其基本思想是:如果一个变量依赖于另一个变量,而这个中间变量又依赖于另一个变量,那么可以通过链式法则把这些依…

第 17 场小白入门赛蓝桥杯

第 17 场小白入门赛 2 北伐军费 发现每次选大的更优,所以可以排序之后,先手取右边,后手取左边。 实际发现,对于 A − B A-B A−B 的结果来说,后手对于这个式子的贡献是 − − a i --a_i −−ai​ ,也就…

使用 Go 和 Gin 框架构建简单的用户和物品管理 Web 服务

使用 Go 和 Gin 框架构建简单的用户和物品管理 Web 服务 在本项目中,我们使用 Go 语言和 Gin 框架构建了一个简单的 Web 服务,能够管理用户和物品的信息。该服务实现了两个主要接口:根据用户 ID 获取用户名称,以及根据物品 ID 获…

多jdk版本环境下,jenkins系统设置需指定JAVA_HOME环境变量

一、背景 由于不同项目对jdk版本的要求不同,有些是要求jdk11,有些只需要jdk8即可。 而linux机器上安装jdk的方式又多种多样,最后导致jenkins打包到底使用的是哪个jdk,比较混乱。 1、java在哪 > whereis java java: /usr/bin/…

【自注意力与Transformer架构在自然语言处理中的演变与应用】

背景介绍 在自然语言处理(NLP)领域,序列到序列(seq2seq)模型和Transformer架构的出现,极大地推动了机器翻译、文本生成和其他语言任务的进展。传统的seq2seq模型通常依赖于循环神经网络(RNN&…

浅聊前后端分离开发和前后端不分离开发模式

1.先聊聊Web开发的开发框架Spring MVC 首先要知道,Spring MVC是Web开发领域的一个知名框架,可以开发基于请求-响应模式的Web应用。而Web开发的本质是遵循HTTP(Hyper Text Transfer Protocol: 超文本传输协议)协议【发请求&#xf…

docker远程端口

docker开启远程端口后,使用本地的访问是不可以访问会docker报错 需要在配置文件中加入sock vi /usr/lib/systemd/system/docker.service 配置文件在 ExecStart/usr/bin/dockerd -H tcp://0.0.0.0:2375 -H uninx://var/run.docker/sock 6443端口也可以使用 systemct…