若是在META-INF/MANIFEST.MF
文件里面设置了Main-Class
属性,那么你就能够很方便的经过java -classpath myapp.jar Main
命令甚至更简洁的java -jar myapp.jar
命令,来启动java虚拟机。这些命令会使用默认的设置来启动JVM。html
要想看到JVM执行时使用在使用哪些参数以及其各参数默认值,能够使用这个命令:java
java -XX:+PrintFlagsFinal -version
api
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
|
bool PrintHeapAtGC = false {product rw}
bool PrintHeapAtGCExtended = false {product rw}
...
uintx AdaptiveSizeDecrementScaleFactor = 4 {product}
uintx AdaptiveSizeMajorGCDecayTimeScale = 10 {product}
uintx AdaptiveSizePausePolicy = 0 {product}
...
bool UseCompressedOops := true {lp64_product}
...
bool UseXmmRegToRegMoveAll = true {ARCH product}
bool VMThreadHintNoPreempt = false {product}
intx VMThreadPriority = -1 {product}
intx VMThreadStackSize = 1024 {pd product}
intx ValueMapInitialSize = 11 {C1 product}
intx ValueMapMaxLoopSize = 8 {C1 product}
intx ValueSearchLimit = 1000 {C2 product}
bool VerifyMergedCPBytecodes = true {product}
...
|
若是这些参数还不够全,你能够打开几个开关:安全
java -XX:+UnlockDiagnosticVMOptions -XX:+UnlockExperimentalVMOptions -XX:+PrintFlagsFinal -version
oracle
大部分的参数均可以安全的看到默认值,可是某些参数须要在生产环境运行时来调整。app
(后面花括号里面有product的表示能够在启动参数中设置的,花括号里面是“product rw”的表示你还能够在jvm启动后使用相似下面的命令来设置这些参数)eclipse
jinfo -flag -PrintHeapAtGC=true <pid>jvm
对java应用而言,最基本的设置莫过于java堆大小的初始值和最大值设置了(通常认为生产环境初始值和最大值设置成同样的比较合适)。jsp
若是你使用的java7或者更早版本的jdk,你可能发现“OutOfMemoryError: PermGen space”,这时你须要使用-XX:MaxPermSize=<size>参数来增大Perm区大小。server虚拟机默认的Perm区大小是64M,但不少应用所需的Perm区空间不止64M。oop
若是JVM虚拟机耗尽了堆空间,且GC垃圾回收不了时,会抛出“java.lang.OutOfMemoryError:Java heap space”,要分析内存占用状况,能够添加参数-XX:+HeapDumpOnOutOfMemoryError参数,这个参数会在抛出java.lang.OutOfMemoryError异常时,dump堆空间的数据到当前工做目录下的一个文件中,-XX:HeapDumpPath=<path>能够指定这个dump文件的具体位置
垃圾回收策略有不少,这里不细说,能够参考Java Garbage Collection Distilled。
无论你正在使用那一个垃圾收集器,你均可以用日志的方式记录一段事件的垃圾回收的过程,来观察垃圾回收的效果。你能够添加参数-verbose:gc来把垃圾回收日志输出到标准输出(STDOUT),但更好的方式是经过参数-Xloggc:<pathtofile>把垃圾回收日志输出到指定的文件。
同时添加-XX:+PrintGCDateStamps参数能够记录下垃圾回收的时间戳,添加-XX:+PrintGCDetails能够记录下垃圾回收的事件细节。
默认状况下,垃圾回收日志文件不断变大,但JVM还内置支持回转日志文件(rotating the file),可搭配使用这三个参数:
-XX:+UseGCLogFileRotation 开启回转日志文件
-XX:GCLogFileSize=8K 设置单个文件最大的文件大小
-XX:NumberOfGCLogFiles=1 设置回转日志文件的个数
最后,你可能须要使用-XX:+DisableExplicitGC参数来显性的关闭手动GC功能(即调用jdk的建议GC的api:System.gc()),让System.gc()方法变成一个空方法,让垃圾回收托管给JVM的垃圾收集器。
java -Xms10g -Xmx10g -XX:MaxPermSize=256m -XX:+HeapDumpOnOutOfMemoryError -XX:+DisableExplicitGC -XX:+UseG1GC -XX:MaxGCPauseMillis=200 -XX:+PrintGCTimeStamps -XX:+PrintGCDetails -Xloggc:/var/log/myapp/gc.log -XX:+UseGCLogFileRotation -XX:GCLogFileSize=10M -XX:NumberOfGCLogFiles=20 -jar myapp.jar
这个例子使虚拟机分配10GB内存和256MB给perm区(java7)。内存溢出时dump堆空间的共鞥启动了,使用G1(garbage first)垃圾收集器,垃圾收集日志记录到/var/log/myapp/gc.log中,同时开启了日志文件回转功能。
原创文章:【译】JVM的默认参数,转载请注明:转载自戎码一辈子