• jvm参数


     官方文档:http://www.oracle.com/technetwork/java/javase/tech/vmoptions-jsp-140102.html

     GC相关---

    -XX:+PrintGCDetails        打印GC日志
    
    -verbose:gc                   打印GC的简要信息
    
    -XX:+PrintGCDetails      打印GC的详细信息
    -Xloggc:log/gc.log    指定GC log的位置
    -XX:+TraceClassLoading    监控类的加载
    -XX:+PrintClassHistogram    按下Ctrl+Break后,打印类的信息

    -------

    -XX:+DoEscapeAnalysis   //使用逃逸分析
    -XX:-DoEscapeAnalysis   //不使用逃逸分析
    默认开启
    -Xms14m -Xmx34m 指定最大堆和最小堆
    System.out.println("Xmx=" + Runtime.getRuntime().maxMemory() / 1024.0 / 1024 + "M");     //系统的最大空间
    
    System.out.println("free mem=" + Runtime.getRuntime().freeMemory() / 1024.0 / 1024 + "M");   //系统的空闲空间
    
    System.out.println("total mem=" + Runtime.getRuntime().totalMemory() / 1024.0 / 1024 + "M");   //当前可用的总空间

     --------------

    -Xmn1m                                设置新生代大小-1M
    -XX:SurvivorRatio=2                      Survivor区
    -XX:NewRatio=1                                    新生代(eden+2*s)
    -Xmx20m -Xms5m -XX:+HeapDumpOnOutOfMemoryError -XX:HeapDumpPath=d:/a.dump                      现在给堆内存最多分配20M的空间。如果发生了OOM异常,那就把dump信息导出到d:/a.dump文件中。
    -XX:+HeapDumpPath                                    导出OOM的路径
    -XX:OnOutOfMemoryError                             在OOM时,执行一个脚本
    -XX:OnOutOfMemoryError=D:/tools/jdk1.7_40/bin/printstack.bat %p                             //p代表的是当前进程的pid 执行printstack.bat脚本,而这个脚本做的事情是:D:/tools/jdk1.7_40/bin/jstack -F %1 > D:/a.txt,即当程序OOM时,在D:/a.txt中将会生成线程的dump
    -XX:PermSize    -XX:MaxPermSize                                永久区分配参数
    -Xss128K        设置栈大小为128k

     -------

       1. 行为参数

    选项和默认值

    值描述

    -XX:-AllowUserSignalHandlers

    允许用户在应用中捕捉信号 (只和Solaris和Linux有关) 

    -XX:AltStackSize=16384

    备用信号栈大小 (Kbytes)。(只Solaris,从5.0删除)

    -XX:-DisableExplicitGC

    禁止调用System.gc(), JVM 依然在必要时执行垃圾回收。

    -XX:+FailOverToOldVerifier

    当新的类型检查器失败时转移到旧的类型检查器上(从6.0开始引进)

    -XX:+HandlePromotionFailure

    年轻代不担保完全提升活所有对象。(1.4.2 update 11引进)(5.0和更早版本是false)

    -XX:+MaxFDLimit

    文件描述符设置到最大(只Solaris)

    -XX:PreBlockSpin=10

    控制多线程自旋锁优化的自旋次数 (1.4.2引进) 

    -XX:-RelaxAccessControlCheck

    在类校验里,放松访问控制检查(6引进) 

    -XX:+ScavengeBeforeFullGC

    full GC之前先youngGC (1.4.1引进) 

    -XX:+UseAltSigs

    为了防止与其他发送信号的应用程序冲突,允许使用候补信号替代 SIGUSR1和SIGUSR2。(1.3.1 update 9引进,1.4.1只Solaris) 

    -XX:+UseBoundThreads

    用户级别线程绑定到核心线程(只Solaris)

    -XX:-UseConcMarkSweepGC

    老年代使用CMS收集(1.4.1引进)

    -XX:+UseGCOverheadLimit

    限制GC的运行时间。如果GC耗时过长,就抛OOM。(6引进) 

    -XX:+UseLWPSynchronization

    使用轻量级进程(内核线程LWP-based)替换线程同步。( 1.4.0引进,只Solaris) 

    -XX:-UseParallelGC Use

    策略为新生代使用并行清除,年老代使用单线程Mark-Sweep-Compact的垃圾收集器。

     (1.4.1引进) 

    -XX:-UseParallelOldGC

    策略为老年代和新生代都使用并行清除的垃圾收集器。开启这个选项,自动开启-XX:+UseParallelGC (5.0 update 6引进) 

    -XX:-UseSerialGC

    使用串行垃圾收集. (5.0引进) 

    -XX:-UseSpinning

    启用多线程自旋锁优化 (1.4.2和5.0需要手动启动) [1.4.2, 多处理器windows平台:true 

    -XX:+UseTLAB

    启用线程本地缓存区(1.4.0引进,之前叫UseTLE) [1.4.2和更早, x86或者-client: false] 

    -XX:+UseSplitVerifier

    使用StackMapTable属性新类型检查(5.0引进)[5.0: false] 

    -XX:+UseThreadPriorities

    使用本地线程优先

    -XX:+UseVMInterruptibleIO

    在I/O进入时或之前线程中断,导致OS_INTRPT。6引进,只Solaris

        2. Garbage First (G1)

    选项和默认值

    描述

    -XX:+UseG1GC

    使用Garbage First (G1) 收集器

    -XX:MaxGCPauseMillis=n

    设置最大暂停时间目标。这是软目标,JVM尽力达到这个目标。

    -XX:InitiatingHeapOccupancyPercent=45

    整个堆占用多少百分比,开始并发GC周期。整个堆,不是一个代。(例如G1)。0表示恒定GC周期。

    -XX:ConcGCThreads=n

    并发收集器线程数,默认值随机器变化。

    -XX:G1ReservePercent=10

    设置预留堆数量,作为false上限,以减少提升失败的几率。

    -XX:G1HeapRegionSize=n

    使用G1堆被分成相等大小区域。这设置每个区域大小。默认值根据堆大小进行功效学计算出来。最小1M,最大32M。

        3. 性能参数

    选项和默认值

    描述

    -XX:+AggressiveOpts

    启用JVM开发团队最新的调优成果。例如编译优化,偏向锁,并行年老代收集等(5.0 update 6.0引进,默认启动) 

    -XX:CompileThreshold=10000

    通过JIT编译器,将方法编译成机器码的触发阀值,可以理解为调用方法的次数,例如调1000次,将方法编译为机器码[-client: 1,500] 

    -XX:LargePageSizeInBytes=4m

    设置java堆使用的内存页最大值(1.4.0 update 1引入) [amd64: 2m.] 

    -XX:MaxHeapFreeRatio=70

    堆最大空闲百分比,大于这个值会自动收缩堆大小

    -XX:MaxNewSize=size

    新生代最大值(bytes)。从1.4开始用NewRatio 计算[1.3.1 Sparc: 32m; 1.3.1 x86: 2.5m.] 

    -XX:MaxPermSize=64m

    永久带大小 [5.0 和以上版本: 64 bit VMs 增大预设值的30% ; 1.4 amd64: 96m; 1.3.1 -client: 32m.] 

    -XX:MinHeapFreeRatio=40

    堆的最小空闲空间,小于这个值会自动扩展堆大小。

    -XX:NewRatio=2

    新/老的比例。 [Sparc -client: 8; x86 -server: 8; x86 -client: 12.]-client: 4 (1.3) 8 (1.3.1+), x86: 12] 

    -XX:NewSize=2m

    新生代默认大小(bytes) [5.0和以上版本: 64 bit VMs增加预设值的30%; x86: 1m; x86, 5.0 and older: 640k] 

    -XX:ReservedCodeCacheSize=32m

    设置代码缓存的最大值,编译时用(bytes) [Solaris 64-bit, amd64, -server x86: 48m; 在1.5.0_06和更早版本,Solaris 64-bit ,amd64: 1024m.] 

    -XX:SurvivorRatio=8

    伊甸园/生还者比例[Solaris amd64: 6; Sparc ,1.3.1: 25; 其他Solaris平台, 5.0 和更早版本: 32] 

    -XX:TargetSurvivorRatio=50

    清理之后,希望生还者区使用的百分比。

    -XX:ThreadStackSize=512

    线程栈大小(Kbytes). (0是默认大小) [Sparc: 512; Solaris x86: 320 (5.0和之前是256); Sparc 64 bit: 1024; Linux amd64: 1024 (5.0和更早是0); 其他0.] 

    -XX:+UseBiasedLocking

    启用偏向锁。(看java调优白皮书的例子5)(5.0 update 6引入) [5.0: false] 

    -XX:+UseFastAccessorMethods

    使用优化版本的基本类型get方法

    -XX:-UseISM

    启用solaris系统的ISM

    -XX:+UseLargePages

    启用大内存分页( 5.0 update 5引入) 看《Java Support for Large Memory Pages》

    -XX:+UseMPSS

    启用solaris的MPSS(多内存页大小),支持w/4mb,不能与ISM同时使用(1.4.0 update 1引入, Solaris 9和更新版本有关.) [1.4.1和更早版本: false] 

    -XX:+UseStringCache

    使用一般缓存分配String

    -XX:AllocatePrefetchLines=1

    用预取指令分配一个对象,如果最后分配是对象是1,如果是数组数3 

    -XX:AllocatePrefetchStyle=1

    预取指令的产生代码风格:

    0-没有预取指令,

    1-每一次分配内存就执行预取指令,

    2-当执行预取代码指令时,用TLAB分配水印指针指向门。

    -XX:+UseCompressedStrings

    用byte[] 代替字符串(从Java6 Update 21开始引入)

    -XX:+OptimizeStringConcat

    可能的话优化字符串连接操作(Java 6 Update 20引入)

        4. 调试参数

    选项和默认值

    描述

    -XX:-CITime

    打印花费在JIT编译花费的时间Prints time spent in JIT Compiler. (1.4.0引进)

    -XX:ErrorFile=./hs_err_pid<pid>.log

    如果发生错误,报错错误数据到这个文件(6引入)

    -XX:-ExtendedDTraceProbes

    驱动性能影响(performance-impacting)动态跟踪探测器 (Introduced in 6引入。只Solaris) 

    -XX:HeapDumpPath=./java_pid<pid>.hprof

    堆转储文件的路径或文件名。可管理 ( 1.4.2 update 12, 5.0 update 7引入)

    -XX:-HeapDumpOnOutOfMemoryError

    当OOM时,转储堆文件。可管理 (1.4.2 update 12, 5.0 update 7引入)

    -XX:OnError="<cmd args>;<cmd args>"

    当发生致命错误时,执行用户定义命令(1.4.2 update 9引入)

    -XX:OnOutOfMemoryError="<cmd args>;<cmd args>"

    当第一次OOM时执行用户定义命令 ( 1.4.2 update 12, 6引入)

    -XX:-PrintClassHistogram

    在Windows下, 按ctrl-break或Linux下是执行kill -3(发送SIGQUIT信号)时,打印class柱状图。jmap -histo提供相同功能(1.4.2引入)

    -XX:-PrintConcurrentLocks

    按Ctrl-Break 打印java.util.concurrent 锁,jstack –l提供相同功能(6引入)

    -XX:-PrintCommandLineFlags

    打印命令行标记 (5.0引入)

    -XX:-PrintCompilation

    当一个方法被编译,答应信息

    -XX:-PrintGC

    当GC时,打印信息。

    -XX:-PrintGCDetails

    当GC时打印详细信息 (1.4.0引入)

    -XX:-PrintGCTimeStamps

    当GC时打印时间戳 (1.4.0引入)

    -XX:-PrintTenuringDistribution

    打印对象存活年龄信息

    -XX:-TraceClassLoading

    打印类加载

    -XX:-TraceClassLoadingPreorder

    按照引用顺序打印所有类加载。 (1.4.2引入)

    -XX:-TraceClassResolution

    打印常量池Trace constant pool resolutions. (1.4.2引入)

    -XX:-TraceClassUnloading

    打印卸载类

    -XX:-TraceLoaderConstraints

    打印类加载策略变化 ( 6引入)

    -XX:+PerfSaveDataToFile

    当推出时,保存jvmstat二进制数据。

    -XX:ParallelGCThreads=n

    给年轻代和老年代平行垃圾收集器,设置垃圾收集线程数默认值随机器变化

    -XX:+UseCompressedOops

    开启压缩指针,为了优化java堆小于32G的64-bit性能(对象引用指针,32 bit 换成64-bit指针)

    -XX:+AlwaysPreTouch

    当JVM初始化时预先对Java堆进行预先摸底(Pre-touch),堆的每个页初始化时满足需求,而不是应用执行时递增。

    -XX:AllocatePrefetchDistance=n

    设置对象分配的预取距离。将要写的在这个距离被预抓取到缓存的新对象的内存值。在最后分配的对象地址之前每个java线程有它自己的分配点。默认值随机器变化。

    -XX:InlineSmallCode=n

    只内联以前编译方法,如果它生成的本地代码大小比这小。默认值随机器变化。

    -XX:MaxInlineSize=35

    内联方法的最大字节码大小

    -XX:FreqInlineSize=n

    一个频繁执行的内联方法的字节码大小。默认值随机器变化。

    -XX:LoopUnrollLimit=n

    当中间表示节点数量小于这个值,展开循环体。在服务器编译之前的限制是这个值的功能,不是真实值。默认值随机器变化。

    -XX:InitialTenuringThreshold=7

    设置初始周期阀值,用于平行年轻收集器的自适应GC调整大小。周期阀值是对象从youngGC生还、提升到老年代的次数。

    -XX:MaxTenuringThreshold=n

    设置最大周期阀值,用于自适应GC调整大小。当前最大值是15。平行收集器是15,CMS是4。

    -Xloggc:<filename>

    指定GC日志文件。日志由正常的日志参数控制。

    -XX:-UseGCLogFileRotation

    开启GC日志分割。必须设置-Xloggc。

    -XX:NumberOfGClogFiles=1

    当分割日志时设置文件数量,必须>= 1。分割的日志使用命名规则<filename>.0, <filename>.1, ..., <filename>.n-1.

    -XX:GCLogFileSize=8K

    日志大小在这个大小时被分割。必须 >= 8K。

     

  • 相关阅读:
    客车网上订票系统项目--会员管理、前端注册页面
    客车网上订票系统项目--管理员管理、前端用户留言
    客车网上订票系统项目--新闻模块
    后端模块-管理员登录、显示留言列表
    前端模块--首页留言页编辑
    前端模块--登录注册界面编辑
    JVM深入理解(一) -JVM初识
    45:漏洞发现-API接口服务之漏洞探针类型利用修复
    42:漏洞发现-操作系统之漏洞探针类型利用修复
    linux系统安全-2
  • 原文地址:https://www.cnblogs.com/chenglc/p/9295728.html
Copyright © 2020-2023  润新知