Java的运行时参数简单总结

简单学习了下Oracle官方的资料:
https://docs.oracle.com/javase/8/docs/technotes/tools/unix/java.html#BABDDFII
之前也遇到了很多问题, 想着一起学习下jvm的参数.
这里简单一边学习一遍翻译了一下
不是很全面, 将自己最近用到的重要参数进行了寿命
其他自己还没有用到的参数就没有列示, 我等菜鸡可以看这个, 高手直接看原文吧.

Java参数分类

正常运行一个Java程序比较简单, 直接java -jar 就可以运行.
但是如何长时间稳定高性能的运行程序就比较复杂, 需要关注比较多的内容
java的参数也比较多,也有一些分类:
1. 标准参数
2. 非标准参数
3. 高级运行时的参数
4. 高级JIT相关的参数
5. 高级系统监控服务类的参数
6. 高级GC相关的参数.

1. 标准参数

-agentlib:jdwp=transport=dt_socket,server=y,address=8000
#可以用来开放调试端口.
-agentpath:pathname[=options]
#可以将pathname里面的agent加载到内存里面
-client -server
#客户端模式,或者是服务端模式.
#client模式启动快,int模式多一些,jit少一些. 运行时效率低
#server模式较早的进行了jit的介入,启动慢,但是运行效率好一些.
-Dproperty=value
#比如可以进行 -Dport=5201就可以运行时修改端口了.

2. 非标准参数

-X
# java -X 可以展示部分非标准参数.
-Xms<size> 设置初始 Java 堆大小
-Xmx<size> 设置最大 Java 堆大小
-Xss<size> 设置 Java 线程堆栈大小
# 注意一般情况下 -Xmx是memory max是 最大的heap内存大小
# -Xms 是初始化最小的的heap内存大小 memory small
# 注意以上两个参数,如果不设置的话: 默认最小内存是系统内存的六十四分之一,最大内存是四分之一.
# 建议 最大内存和最小内存设置成一样大小, 这样可以避免jvm的内存缩减扩容影响性能.
# Xss 是java线程的栈区大小, 注意一般中文翻译的 堆栈的说法总会让人产生误解.
# 需要注意 Xss的内存不是堆区管理的. 占用的总内存可以理解为 threads数*Xss的数值.
# 栈区太大了会占用较多的内存,并且创建线程速度也会变慢, 但是如果太小,很容易出现stackoverflow.
部分系统默认的栈区大小:
Linux/ARM (32-bit): 320 KB
Linux/i386 (32-bit): 320 KB
Linux/x64 (64-bit): 1024 KB
OS X (64-bit): 1024 KB
Oracle Solaris/i386 (32-bit): 320 KB
Oracle Solaris/x64 (64-bit): 1024 KB

2.非标准参数

-XX:NewRatio
#-XX:NewRatio=4表示年轻代与年老代所占比值为1:4,年轻代占整个堆栈的1/5
# Xms=Xmx并且设置了Xmn的情况下,该参数不需要进行设置。
-XX:SurvivorRatio
#设置为8,则两个Survivor区与一个Eden区的比值为2:8,
#一个Survivor区占整个年轻代的1/10
-Xbatch # 禁用后台编译
-Xmixed 混合模式执行 (默认)
-Xint 仅解释模式执行
-Xcomp 强制进行编译.
# 注意可以使用这个参数设定 多少次的进行编译. -XX:CompileThreshold
# 默认情况下 client 是1000次 server是10000次.
-Xnoclassgc
# 启用这两个参数后gc时将不会清理类对象,可能会出现内存浪费甚至内存泄漏问题,
# 如果情况严重可能会填满持久代。
-Xprof
# 能够将jvm运行时的性能数据展示到标准输出,开发测试有效
# 编译用于生产会影响性能.

3. 高级运行时的参数

-XX:ErrorFile=filename
# 严重错误时能够将错误日志打印出来默认在当前运行时的路径.
-XX:+FlightRecorder -XX:-FlightRecorder
# 使用启用FilghtRecorder + 表示启用 - 表示禁用.
XX:LargePageSizeInBytes=size
# 内存页面大小, 必须为2的幂, 一般不建议设置,容易出问题.
-XX:MaxDirectMemorySize=size
# nio 使用本地内存的大小,好像有一个64m的问题因这个导致.
-XX:NativeMemoryTracking=mode
#off summary detail 三种模式, 用于监控jvm的本地内存.
-XX:+TraceClassLoading
# 跟踪类的加载
-XX:-UseCompressedOops
# 不适用类指针压缩,一般32g一下的堆区自动之争压缩,32g以上不能使用.

4. 高级JIT编译器的参数

-XX:CICompilerCount=threads
# 设置编译器的数量,server模式默认为2,client模式默认为1
-XX:CodeCacheMinimumFreeSpace=size
# 设置代码缓存吃的最小空闲空间. ARM上面code cache 好像跟x86不太一样.
-XX:CompileThreshold=invocations
# 设置默认编译的最小调用次数.
-XX:+DoEscapeAnalysis
# 逃逸分析, 如果确认不会被其他线程使用可以直接栈上分配内存.提高内存部署效率
# 栈上分配能够使用寄存器,效率比物理内存(主内存)高两个数量级.
-XX:InitialCodeCacheSize=size
# CodeCache如果太小, 会影响性能, 导致方法只能int执行不能complie执行.
-XX:ReservedCodeCacheSize=size
# 可以开启分层加载, 会影响启动速度,但是有助于减少部分codecache的使用.

5. 高级服务监控参数

-XX:+HeapDumpOnOutOfMemoryError
# 开发利器运维噩梦.磁盘会爆满,但是会保留犯罪现场,有助于排查问题.
-XX:HeapDumpPath=path
# 别跟应用在一起, 避免磁盘满了 业务停了.运维背锅.
-XX:+PrintClassHistogram
# 停止服务时打印类的统计图.

6. 高级GC方面的参数

-XX:ActiveProcessorCount=x
# 感觉vm超售很严重时可能有些用处,不过是牺牲自己照亮别人.
-XX:ConcGCThreads=threads
# 并行GC的线程数..
-XX:+DisableExplicitGC
# 禁用了显示调用 system.gc() 如果有nio直接使用堆外内存的情况下,
# 禁用了ExplicitGC可能会出现堆外内存异常.
-XX:MaxRAMPercentage=percent
# 之前说了默认值是 25, 如果是专用机器可以适当改成60甚至更高.
# 但是注意还有堆外内存还有方法区,直接内存等,不要设置的太高.
-XX:MaxTenuringThreshold=threshold
# 好像存活多少次就会晋升到老年代的含义.并行GC默认15.CMS默认是6,最高值是15
-XX:MetaspaceSize=size
# 元空间的设置, jdk8没有了持久代的含义..
-XX:ParallelGCThreads=threads
# 默认值是CPU的个数, 所有有时候疯狂GC是CPU 就被占满了机器卡爆
# 不知道能否设置成低于CPU的个数,保证部分业务使用.
# fast failure的原理是需要尽快宕机的
-XX:+PrintGC
# 打印GC的信息.
-XX:+PrintGCDateStamps
-XX:+PrintGCDetails
# 打印GC的时间戳和GC的详细信息
-XX:TLABSize=size
# 这个参数没玩过, 暂时不清楚 我理解成slab了..
-XX:+UseGCOverheadLimit
# 好像就是 98%堆内存无法被回收时直接干掉jvm显示为oom. fast failure
-XX:+UseNUMA
# NUMA 很多程序的痛苦..
-XX:+UseParallelGC
-XX:+UseParallelOldGC
-XX:+UseParNewGC
-XX:+UseSerialGC
# 好多种不同的GC方式,需要验证再改,如果水平跟我差不多,就不要改默认.

随性翻译: Java的运行时参数简单总结的更多相关文章

  1. Java虚拟机运行时栈帧结构--《深入理解Java虚拟机》学习笔记及个人理解(二)

    Java虚拟机运行时栈帧结构(周志明书上P237页) 栈帧是什么? 栈帧是一种数据结构,用于虚拟机进行方法的调用和执行. 栈帧是虚拟机栈的栈元素,也就是入栈和出栈的一个单元. 2018.1.2更新(在 ...

  2. Java程序运行时内存划分

    1.Java程序跨平台运行的原因 主要原因是:各种平台的JVM和字节码文件 Java源程序--具体平台的机器代码文件---被编译器翻译成平台无关的Class文件,又用特定JVM运行字节码文件,JVM在 ...

  3. <JVM下篇:性能监控与调优篇>04-JVM运行时参数

    笔记来源:尚硅谷JVM全套教程,百万播放,全网巅峰(宋红康详解java虚拟机) 同步更新:https://gitee.com/vectorx/NOTE_JVM https://codechina.cs ...

  4. 《深入理解Java虚拟机》(二)Java虚拟机运行时数据区

    Java虚拟机运行时数据区 详解 2.1 概述 本文参考的是周志明的 <深入理解Java虚拟机>第二章 ,为了整理思路,简单记录一下,方便后期查阅. 2.2 运行时数据区域 Java虚拟机 ...

  5. 查看JVM运行时参数

    1.查看JVM运行时参数 -XX:+PrintFlagsInitial -XX:PrintFlagsFinal -XX:+UnlockExperimentalVMOptions 解锁实验参数 -XX: ...

  6. Hadoop JobTracker和NameNode运行时参数查看

      1)JobTracker运行时参数: hadoop@ubuntu:/home/zhangchao3$ ps -ef | grep job hadoop 29563 1 0 11:34 pts/12 ...

  7. java程序运行时内存分配详解

    java程序运行时内存分配详解 这篇文章主要介绍了java程序运行时内存分配详解 ,需要的朋友可以参考下   一. 基本概念 每运行一个java程序会产生一个java进程,每个java进程可能包含一个 ...

  8. JVM探秘:jinfo查看JVM运行时参数

    本系列笔记主要基于<深入理解Java虚拟机:JVM高级特性与最佳实践 第2版>,是这本书的读书笔记. 如何查看JVM运行时参数,对于线上JVM调优是很关键的,因为只有知道了当前使用的JVM ...

  9. [JVM教程与调优] 什么是JVM运行时参数?

    我们接着上一章节[JVM教程与调优] JVM都有哪些参数类型?的内容继续讲解,这章我们来介绍一下:如何查看JVM运行时参数.这一点十分重要,因为我们在进行JVM参数调优的时候,我们首先得知道目前系统运 ...

  10. 面试常问的 Java 虚拟机运行时数据区

    写在前面 本文描述的有关于 JVM 的运行时数据区是基于 HotSpot 虚拟机. 概述 JVM 在执行 Java 程序的过程中会把它所管理的内存划分为若干个不同的数据区域.这些区域都有各自的用途,以 ...

随机推荐

  1. 教你用Python自制拼图小游戏,轻松搞定熊孩子

    摘要:本文主要为大家详细介绍了python实现拼图小游戏,文中还有示例代码介绍,感兴趣的小伙伴们可以参考一下. 开发工具 Python版本:3.6.4 相关模块: pygame模块: 以及一些Pyth ...

  2. FusionInsight MRS Flink DataStream API读写Hudi实践

    摘要:目前Hudi只支持FlinkSQL进行数据读写,但是在实际项目开发中一些客户存在使用Flink DataStream API读写Hudi的诉求. 本文分享自华为云社区<FusionInsi ...

  3. 在毫秒量级上做到“更快”!DataTester 助力飞书提升页面秒开率

    更多技术交流.求职机会,欢迎关注字节跳动数据平台微信公众号,回复[1]进入官方交流群 用户体验是决定互联网产品能否长久生存的基础,每一个基于产品功能.使用.外观的微小体验,都将极大关系到用户留存影响. ...

  4. 火山引擎 DataTester:A/B 测试,让企业摆脱广告投放“乱烧钱”

    更多技术交流.求职机会,欢迎关注字节跳动数据平台微信公众号,回复[1]进入官方交流群 在广告投放的场景下,一线广告优化师通常会创建多个计划,去测试不同的广告素材效果.这套方法看似科学,实际上却存在诸多 ...

  5. Solon2 开发之IoC,三、注入或手动获取 Bean

    1.如何注入Bean? 先了解一下Bean生命周期的简化版: 运行构建函数 尝试字段注入(有时同步注入,没时订阅注入.不会有相互依赖而卡住的问题) @Init 函数(是在容器初始化完成后才执行) .. ...

  6. WPF 自定义可拖动标题栏

    要注意,拖拽的地方,需要加背景色,否则 DrageMove 将无效 MainWindows.xaml <Window x:Class="Report.MainWindow" ...

  7. 低风险稳健策略:BTC套利策略

    更多精彩内容,欢迎关注公众号:数量技术宅,也可添加技术宅个人微信号:sljsz01,与我交流. 币安零手续费带来的机会 从7月8日的20点开始,币安推出了BTC现货交易零手续费的优惠活动,不论是Mak ...

  8. TypeError: this.libOptions.parse is not a function

    安装完node.js运行项目后,报错: TypeError: this.libOptions.parse is not a function at ESLint8Plugin.<anonymou ...

  9. WCF 使用动态代理精简代码架构 (WCF动态调用)

    使用Castle.Core.dll实现,核心代码是使用Castle.DynamicProxy.ProxyGenerator类的CreateInterfaceProxyWithoutTarget方法动态 ...

  10. [网络克隆]利用tiny proxy实现局域网内批量安装WINDOWS操作系统。

    说明:本文支持UEFI及BIOS系统克隆.支持UEFI及BIOS网络引导,适用于新旧几乎所有支持网络启动的电脑. 事前准备: 保证被克隆的电脑为同一配置,或者各硬件差异不大,比如CPU同如英特尔8代的 ...