为什么总是" GC(分配失败)"?
用于linux-amd64 JRE的Java HotSpot(TM)64位服务器VM(25.25-b02)( 1.8.0_25 -b17),
CommandLine flags:
-XX:CMSInitiatingOccupancyFraction=60
-XX:GCLogFileSize=10485760
-XX:+HeapDumpOnOutOfMemoryError
-XX:InitialHeapSize=32212254720
-XX:MaxHeapSize=32212254720
-XX:NewRatio=10
-XX:OldPLABSize=16
-XX:ParallelGCThreads=4
-XX:+PrintGC
-XX:+PrintGCDetails
-XX:+PrintGCTimeStamps
-XX:+PrintStringTableStatistics
-XX:+PrintTenuringDistribution
-XX:StringTableSize=1000003
-XX:SurvivorRatio=4
-XX:TargetSurvivorRatio=50
-XX:+UseCompressedClassPointers
-XX:+UseCompressedOops
-XX:+UseParNewGC
-XX:+UseConcMarkSweepGC
27.329: [GC (Allocation Failure) 27.329: [ParNew
Desired survivor size 44728320 bytes, new threshold 15 (max 15)
- age 1: 16885304 bytes, 16885304 total
: 349568K->16618K(436928K), 0.2069129 secs] 349568K->16618K(31369920K), 0.2070712 secs] [Times: user=0.78 sys=0.04, real=0.21 secs]
28.210: [GC (Allocation Failure) 28.210: [ParNew
Desired survivor size 44728320 bytes, new threshold 15 (max 15)
- age 1: 28866504 bytes, 28866504 total
- age 2: 12582536 bytes, 41449040 total
: 366186K->47987K(436928K), 0.2144807 secs] 366186K->47987K(31369920K), 0.2146024 secs] [Times: user=0.84 sys=0.01, real=0.22 secs]
29.037: [GC (Allocation Failure) 29.038: [ParNew
Desired survivor size 44728320 bytes, new threshold 2 (max 15)
- age 1: 28443488 bytes, 28443488 total
- age 2: 28386624 bytes, 56830112 total
- age 3: 12579928 bytes, 69410040 total
: 397555K->76018K(436928K), 0.2357352 secs] 397555K->76018K(31369920K), 0.2358535 secs] [Times: user=0.93 sys=0.01, real=0.23 secs]
答案 0 :(得分:163)
"分配失败"是导致GC周期开始的原因。
"分配失败"意味着Eden中没有剩余空间来分配对象。因此,这是年轻GC的正常原因。
较旧的JVM没有打印GC导致较小的GC循环。
"分配失败"几乎只有可能导致次要GC的原因。轻微GC启动的另一个原因可能是CMS备注阶段(如果启用了+XX:+ScavengeBeforeRemark
)。
答案 1 :(得分:4)
“分配失败”是导致GC踢不正确的原因。 这是GC操作的结果。
在没有可分配空间的情况下启动GC(取决于执行次要或主要GC的区域)。 一旦执行了GC,如果释放的空间足够好,但是如果空间不足,那么它将失败。 分配失败就是这样的失败之一。 下面的文件有很好的解释 https://docs.oracle.com/javase/8/docs/technotes/guides/vm/gctuning/g1_gc.html
答案 2 :(得分:-10)
在jdk1.8中使用CMS GC时会出现此错误,我更改了G1 Gc解决了这个问题。
THREE.ObjectLoader()