0

0

JDK元空间_不同JDK版本中元空间的实现变化

煙雲

煙雲

发布时间:2026-01-08 14:48:04

|

389人浏览过

|

来源于php中文网

原创

JDK 8至21元空间实现持续演进:JDK 8引入本地内存管理;JDK 9–10增强碎片控制与MetaspaceSize语义变更;JDK 11适配ZGC支持并发回收;JDK 17优化mmap映射并适配cgroup;JDK 21提升统计精度并标准化诊断接口。

jdk元空间_不同jdk版本中元空间的实现变化 - php中文网

如果您正在分析JDK中元空间(Metaspace)的行为差异,却发现不同JDK版本间GC日志、内存占用或OOM触发条件不一致,则很可能是由于元空间底层实现机制发生了演进。以下是针对不同JDK版本中元空间实现变化的关键解析:

一、JDK 8:元空间的初始引入与本地内存管理

JDK 8正式移除永久代(PermGen),以元空间替代,其核心目标是避免因类加载器泄漏导致的不可控OutOfMemoryError: PermGen space。元空间初始实现完全基于本地内存(Native Memory),由Class Metadata Allocator统一管理,不再受JVM堆大小限制,但受限于操作系统可用内存及MaxMetaspaceSize参数。

1、元空间内存块通过mmap系统调用直接申请,每个块大小默认为2MB(Chunk Size)。

2、每个类加载器持有独立的MetaspaceArena,Arena内部按Chunk组织,Chunk进一步划分为小块(Small Chunk)和大块(Humongous Chunk)用于不同大小的元数据分配。

3、当发生类卸载时,仅释放对应ClassLoader关联的Arena,但Chunk内存不会立即归还操作系统,而是加入空闲链表等待复用。

二、JDK 9–10:元空间碎片控制与回收策略增强

为缓解长期运行应用中因频繁类加载/卸载引发的元空间内存碎片问题,JDK 9起引入了更积极的Chunk复用逻辑和惰性回收机制。此时元空间仍不主动向OS释放内存,但增加了对“可合并空闲Chunk”的识别能力,提升后续分配效率。

1、引入FreeChunkList按大小分级维护空闲Chunk,减少遍历开销。

2、在Full GC后触发MetaspaceGC::purge,尝试将多个相邻空闲Small Chunk合并为一个Medium Chunk。

3、MetaspaceSize参数作用发生变化:从JDK 9起,该值仅作为首次触发元空间GC的阈值,而非初始提交内存大小

三、JDK 11:ZGC支持下的元空间并发回收准备

JDK 11为适配ZGC等低延迟收集器,对元空间元数据结构进行了非阻塞化改造。关键变化在于ClassLoaderData(CLD)的生命周期管理与元空间释放解耦,允许在无STW前提下完成部分元数据清理。

1、CLD对象不再强引用其MetaspaceArena,改为通过弱引用+引用队列跟踪可回收状态。

聚好用AI
聚好用AI

可免费AI绘图、AI音乐、AI视频创作,聚集全球顶级AI,一站式创意平台

下载

2、元空间回收线程(MetaspaceGC thread)可异步扫描并标记无引用的Chunk,但实际释放仍需等待安全点(Safepoint)执行。

3、启用-XX:+UnlockExperimentalVMOptions -XX:+UseZGC时,元空间分配路径新增CAS原子操作保障并发安全性

四、JDK 17:元空间内存映射优化与容器环境适配

针对云原生场景,JDK 17强化了元空间对cgroup v1/v2内存限制的感知能力,并改进了mmap区域的地址空间布局策略,降低因地址空间碎片导致的分配失败概率。

1、当检测到cgroup memory.limit_in_bytes存在时,自动将MaxMetaspaceSize设为该值的75%,防止超限被OOM Killer终止。

2、引入MmapRegionPool机制,预分配若干固定大小的mmap区域(默认4个,各64MB),减少高频mmap系统调用开销。

3、使用-XX:MaxMetaspaceExpansion参数可控制单次扩容最大增量,默认值从JDK 11的4MB提升至JDK 17的16MB

五、JDK 21:元空间统计精度提升与诊断接口标准化

JDK 21将元空间内部状态暴露为JVMTI和JMX标准接口的一部分,同时修正了早期版本中因Chunk未及时归还导致的MemoryUsage.getUsed()值虚高问题。

1、MetaspaceUtils::used_words_slow()方法改用原子计数器聚合各Arena已用字数,消除锁竞争。

2、jstat -gc输出中Metaspace相关字段(MU、MC、CCSU)更新为基于实时Chunk状态计算,而非依赖周期性采样。

3、新增DiagnosticCommand jcmd VM.metaspace -all,可输出每个ClassLoaderData的精确元空间占用及Chunk分布详情

相关专题

更多
treenode的用法
treenode的用法

​在计算机编程领域,TreeNode是一种常见的数据结构,通常用于构建树形结构。在不同的编程语言中,TreeNode可能有不同的实现方式和用法,通常用于表示树的节点信息。更多关于treenode相关问题详情请看本专题下面的文章。php中文网欢迎大家前来学习。

532

2023.12.01

C++ 高效算法与数据结构
C++ 高效算法与数据结构

本专题讲解 C++ 中常用算法与数据结构的实现与优化,涵盖排序算法(快速排序、归并排序)、查找算法、图算法、动态规划、贪心算法等,并结合实际案例分析如何选择最优算法来提高程序效率。通过深入理解数据结构(链表、树、堆、哈希表等),帮助开发者提升 在复杂应用中的算法设计与性能优化能力。

17

2025.12.22

深入理解算法:高效算法与数据结构专题
深入理解算法:高效算法与数据结构专题

本专题专注于算法与数据结构的核心概念,适合想深入理解并提升编程能力的开发者。专题内容包括常见数据结构的实现与应用,如数组、链表、栈、队列、哈希表、树、图等;以及高效的排序算法、搜索算法、动态规划等经典算法。通过详细的讲解与复杂度分析,帮助开发者不仅能熟练运用这些基础知识,还能在实际编程中优化性能,提高代码的执行效率。本专题适合准备面试的开发者,也适合希望提高算法思维的编程爱好者。

7

2026.01.06

硬盘接口类型介绍
硬盘接口类型介绍

硬盘接口类型有IDE、SATA、SCSI、Fibre Channel、USB、eSATA、mSATA、PCIe等等。详细介绍:1、IDE接口是一种并行接口,主要用于连接硬盘和光驱等设备,它主要有两种类型:ATA和ATAPI,IDE接口已经逐渐被SATA接口;2、SATA接口是一种串行接口,相较于IDE接口,它具有更高的传输速度、更低的功耗和更小的体积;3、SCSI接口等等。

1007

2023.10.19

PHP接口编写教程
PHP接口编写教程

本专题整合了PHP接口编写教程,阅读专题下面的文章了解更多详细内容。

56

2025.10.17

php8.4实现接口限流的教程
php8.4实现接口限流的教程

PHP8.4本身不内置限流功能,需借助Redis(令牌桶)或Swoole(漏桶)实现;文件锁因I/O瓶颈、无跨机共享、秒级精度等缺陷不适用高并发场景。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

346

2025.12.29

堆和栈的区别
堆和栈的区别

堆和栈的区别:1、内存分配方式不同;2、大小不同;3、数据访问方式不同;4、数据的生命周期。本专题为大家提供堆和栈的区别的相关的文章、下载、课程内容,供大家免费下载体验。

382

2023.07.18

堆和栈区别
堆和栈区别

堆(Heap)和栈(Stack)是计算机中两种常见的内存分配机制。它们在内存管理的方式、分配方式以及使用场景上有很大的区别。本文将详细介绍堆和栈的特点、区别以及各自的使用场景。php中文网给大家带来了相关的教程以及文章欢迎大家前来学习阅读。

567

2023.08.10

Golang 分布式缓存与高可用架构
Golang 分布式缓存与高可用架构

本专题系统讲解 Golang 在分布式缓存与高可用系统中的应用,涵盖缓存设计原理、Redis/Etcd集成、数据一致性与过期策略、分布式锁、缓存穿透/雪崩/击穿解决方案,以及高可用架构设计。通过实战案例,帮助开发者掌握 如何使用 Go 构建稳定、高性能的分布式缓存系统,提升大型系统的响应速度与可靠性。

53

2026.01.09

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
WEB前端教程【HTML5+CSS3+JS】
WEB前端教程【HTML5+CSS3+JS】

共101课时 | 8.2万人学习

JS进阶与BootStrap学习
JS进阶与BootStrap学习

共39课时 | 3.1万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号