随性翻译: Java的运行时参数简单总结

java

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的运行时参数简单总结 的全部内容, 来源链接: utcz.com/z/389716.html

回到顶部