bin4一般是什么参数,怎么鉴定bin407

首页 > 经验 > 作者:YD1662022-10-27 10:47:50

作者:qbit snap

链接:https://segmentfault.com/a/1190000022603726

前言

-Xms8g -Xmx8g

bin4一般是什么参数,怎么鉴定bin407(1)

Client/Server

λ java -version java version "1.8.0_162" Java(TM) SE Runtime Environment (build 1.8.0_162-b12) Java HotSpot(TM) 64-Bit Server VM (build 25.162-b12, mixed mode)

打印 JVM 参数

λjava-XX: PrintFlagsInitial

λjava-XX: PrintFlagsFinal2>nul

# 输出经由人工换行 λ java -XX: PrintCommandLineFlags 2> nul -XX:InitialHeapSize=266579392 -XX:MaxHeapSize=4265270272 -XX: PrintCommandLineFlags -XX: UseCompressedClassPointers -XX: UseCompressedOops -XX:-UseLargePagesIndividualAllocation -XX: UseParallelGC

jvm 内存模型

bin4一般是什么参数,怎么鉴定bin407(2)

常用参数

-Xms: 初始堆大小 -Xmx: 最大堆大小 -XX:NewSize: 年轻代初始化内存的大小(注意:该值需要小于-Xms的值) -XX:MaxnewSize: 年轻代可被分配的内存的最大上限(注意:该值需要小于-Xmx的值) 从 JKD1.4 开始,MaxnewSize 是通过 NewRatio 计算出来的 -Xmn: 对-XX:newSize、-XX:MaxnewSize两个参数同时进行配置(JDK1.4之后才有该参数) 官方推荐为对大小的 3/8,即 1/4 到 1/3 之间 -XX:NewRatio: 设置老年代和年轻代的比值 若 -Xmn 已指定,则 OldSize = HeapSize - NewSize,无需再按比例计算。 例如 NewRatio 为 3,表示 老年代/年轻代 = 3,年轻代占整个堆内存大小的 1/4

# 摘录的部分的输出行 # MaxHeapSize/MaxNewSize = 4265607168/1421869056 = 3 λ java -XX: PrintFlagsFinal uintx NewRatio = 2 {product} uintx MaxNewSize := 1421869056 {product} uintx MaxHeapSize := 4265607168 {product}

CompressedOops

压缩普通对象指针

compressed ordinary object pointers,压缩普通对象指针

(0, 2GB] Compressed Oops mode: 32-bit [2GB, 26GB] Compressed Oops mode: Zero based,26G不是确切值,视系统而定 (26GB, 32GB) Compressed Oops mode: Non-zero disjoint base,32G不是确切值,视系统而定 [32GB, ) CompressedOops 失效,32G不是确切值,视系统而定

bin4一般是什么参数,怎么鉴定bin407(3)

检查 CompressedOops 阈值

# CompressedOops 阈值 # 32 G,false 表示超过了阈值 $ ./jdk/bin/java -Xmx32g -XX: PrintFlagsFinal 2> /dev/null | grep UseCompressedOops bool UseCompressedOops = false {lp64_product} # 31G,true 表示在阈值之内 $ ./jdk/bin/java -Xmx31g -XX: PrintFlagsFinal 2> /dev/null | grep UseCompressedOops bool UseCompressedOops := true {lp64_product}

# zero based Compressed Oops 阈值 # 31G,Non-zero ./jdk/bin/java -server -Xms31G -Xmx31G -XX: UnlockDiagnosticVMOptions -Xlog:gc heap coops=info -version [0.134s][info][gc,heap,coops] Heap address: 0x0000001000800000, size: 31744 MB, Compressed Oops mode: Non-zero disjoint base: 0x0000001000000000, Oop shift amount: 3 openjdk 13.0.2 2020-01-14 OpenJDK Runtime Environment AdoptOpenJDK (build 13.0.2 8) OpenJDK 64-Bit Server VM AdoptOpenJDK (build 13.0.2 8, mixed mode, sharing) # 30G,Zero based ./jdk/bin/java -server -Xms30G -Xmx30G -XX: UnlockDiagnosticVMOptions -Xlog:gc heap coops=info -version [0.128s][info][gc,heap,coops] Heap address: 0x0000000080000000, size: 30720 MB, Compressed Oops mode: Zero based, Oop shift amount: 3 openjdk version "13.0.1" 2019-10-15 OpenJDK Runtime Environment AdoptOpenJDK (build 13.0.1 9) OpenJDK 64-Bit Server VM AdoptOpenJDK (build 13.0.1 9, mixed mode, sharing)

测试案例

这个案例中,分配 32g比31g能创建的对象少了50% 587889429/385481085≈1.525

bin4一般是什么参数,怎么鉴定bin407(4)

这个案例中,48g才基本达到31g的效果

bin4一般是什么参数,怎么鉴定bin407(5)

本文出自

栏目热文

文档排行

本站推荐

Copyright © 2018 - 2021 www.yd166.com., All Rights Reserved.