JVM 的 TLAB(Thread-Local Allocation Buffer)是什么?
JVM 的 TLAB(Thread-Local Allocation Buffer)是什么?
TLAB(Thread-Local Allocation Buffer)简介
TLAB(Thread-Local Allocation Buffer) 是 JVM 中堆内存管理的一种优化技术,用于减少多线程环境下对象分配的竞争,提高分配对象的效率。它为每个线程分配一块独立的小堆空间,专门用于分配新对象,从而避免线程间的锁争用。
TLAB 的工作原理
线程独占:
- 每个线程在堆(Heap)的年轻代 Eden 区中分配一块 TLAB 空间。
- 这块内存是线程私有的,其他线程不能访问。
对象分配:
- 当线程需要分配新对象时,直接从自己的 TLAB 中分配。
- 如果 TLAB 空间不足,才会尝试向堆的共享内存区域分配。
TLAB 的生命周期:
- 当 TLAB 的空间用完时,线程会尝试申请一个新的 TLAB。
- 如果无法分配新的 TLAB,线程会退回到传统的堆分配策略。
内存回收:
- TLAB 是年轻代的一部分,当年轻代发生垃圾回收时,未使用完的 TLAB 空间也会被回收。
TLAB 的优点
减少竞争:
- 线程分配对象时,直接操作自己的 TLAB,无需加锁或同步,避免线程争用锁的开销。
分配速度快:
- 分配对象时,仅需修改 TLAB 中的指针,比从堆中分配的成本更低。
提升性能:
- 在多线程环境下,对象分配的性能提升明显。
TLAB 的分配规则
TLAB 的大小:
- 每个 TLAB 的大小是从堆内存中分配的,并根据线程的分配频率动态调整。
- 通常,TLAB 的大小可以通过 JVM 参数调整(见下文)。
TLAB 的适用范围:
- TLAB 主要用于分配年轻代(Eden 区)的小对象。
- 对于大对象(超出 TLAB 大小的对象),会直接分配到堆(可能是老年代)。
TLAB 的相关 JVM 参数
- 启用或禁用 TLAB:
- -XX:+UseTLAB:启用 TLAB(默认启用)。
- -XX:-UseTLAB:禁用 TLAB。
- TLAB 初始大小:
- -XX:TLABSize=<size>:设置 TLAB 的初始大小(以字节为单位)。
- 一般不需要手动设置,JVM 会根据应用动态调整。
- TLAB 使用率阈值:
- -XX:TLABWasteTargetPercent=<percent>:设置 TLAB 使用率的目标阈值,未达到该使用率的 TLAB 会被视为浪费。
- 打印 TLAB 使用信息:
- -XX:+PrintTLAB:在 GC 日志中打印 TLAB 的分配和使用情况。
监控和调优 TLAB
- 监控 TLAB 使用情况:
- 开启 -XX:+PrintGCDetails 和 -XX:+PrintTLAB,可以在 GC 日志中查看 TLAB 的分配和回收信息。
- 调优 TLAB 大小:
- 如果对象分配频率高而 TLAB 空间频繁不足,可以增加 TLAB 的大小。
- 通过 -XX:TLABSize 或调整年轻代的大小(-Xmn 参数)间接影响 TLAB 的大小。
总结
TLAB 是 JVM 为优化对象分配设计的机制,通过给每个线程分配独立的小堆内存区域,减少了多线程竞争对堆内存的争用。它主要用于年轻代的小对象分配,在高并发场景下能显著提高内存分配的效率。由于 TLAB 是默认启用的,通常不需要手动调整,只有在性能调优时才需关注其参数设置和使用情况。
JVM 的 TLAB(Thread-Local Allocation Buffer)是什么?的更多相关文章
- 线程TLAB局部缓存区域(Thread Local Allocation Buffer)
TLAB(Thread Local Allocation Buffer) 1,堆是JVM中所有线程共享的,因此在其上进行对象内存的分配均需要进行加锁,这也导致了new对象的开销是比较大的 2,Sun ...
- 堆中的线程私有缓存区域TLAB(Thread Local Allocation Buffer)
TLAB产生的原因 堆区是线程共享区域,任何线程都可以访问到堆区中的共享数据 由于对象实例的创建在JVM中非常频繁,因此在并发环境下从堆区中划分内存空间是线程不安全的 为避免多个线程操作同一地址,需要 ...
- HBase 中 Memstore-Local Allocation Buffer
在0.90 版本后的 HBase,引入了一个高级机制用于缓解堆内存碎片的问题.此内存碎片问题的产生的主要原因是由于 memstore 上的扰动(频繁的分配与释放内存空间)导致.对应解决此问题的机制为M ...
- TLS 与 python thread local
TLS 先说TLS( Thread Local Storage),wiki上是这么解释的: Thread-local storage (TLS) is a computer programming m ...
- Python thread local
由于GIL的原因,笔者在日常开发中几乎没有用到python的多线程.如果需要并发,一般使用多进程,对于IO Bound这种情况,使用协程也是不错的注意.但是在python很多的网络库中,都支持多线程, ...
- Java进阶(七)正确理解Thread Local的原理与适用场景
原创文章,始自发作者个人博客,转载请务必将下面这段话置于文章开头处(保留超链接). 本文转发自技术世界,原文链接 http://www.jasongj.com/java/threadlocal/ Th ...
- Java Thread Local – How to use and code sample(转)
转载自:https://veerasundar.com/blog/2010/11/java-thread-local-how-to-use-and-code-sample/ Thread Local ...
- Python - python3.7新增的contextvars vs Thread local(threading.local)
总结 和threading.local()类似.Python3.7新增. thread.local(): 不同线程,同一个变量保存不同的值. contextvars: 不同上下文,同一个变量保存不同的 ...
- 线程本地存储TLS(Thread Local Storage)的原理和实现——分类和原理
原文链接地址:http://www.cppblog.com/Tim/archive/2012/07/04/181018.html 本文为线程本地存储TLS系列之分类和原理. 一.TLS简述和分类 我们 ...
- 线程本地存储(Thread Local Storage, TLS)简单分析与使用
在多线程编程中, 同一个变量, 如果要让多个线程共享访问, 那么这个变量可以使用关键字volatile进行声明; 那么如果一个变量不想使多个线程共享访问, 那么该怎么办呢? 呵呵, 这个办法就是TLS ...
随机推荐
- Goh:一款Go语言的预编译快速模板引擎。(Benchmark排名第一)
https://github.com/OblivionOcean/Goh Goh 是一款Go语言的预编译快速模板引擎. English | 简体中文 目录 特性 性能测试 安装 使用 语法 特性 预编 ...
- Luogu P3041 USACO12JAN Video Game G 题解 [ 紫 ] [ AC 自动机 ] [ 动态规划 ]
Video Games G:弱智紫题,30min 切了,dp 思路非常板. 多模式串一看肯定就是要建出 AC 自动机,然后在 fail 树里下传标记,预处理每个节点到达后的得分. 然后设计 \(dp_ ...
- CSP2024 to do list...
马上 CSP 了,感觉得开始培养状态了. 哈希练习 Tarjan 初步学习+刷题 大模拟练习:鸭棋+猪国杀 S 组初赛,选择题部分,刷整卷至少 3 套. 树状数组练习:DX视频 线段树优化 dp 练习 ...
- Typora Emoji图标
转自: https://www.cnblogs.com/wangjs-jacky/p/12011208.html People :smile: :laughing: :blush: :sm ...
- WPF程序性能优化总结
原文链接: https://blog.csdn.net/u010265681/article/details/77571947 WPF程序性能由很多因素造成,以下是简单地总结: 元素: 1. 减少需要 ...
- 浅析Bootstrap中Tab(标签页)的使用方法
Bootstrap 导航元素使用相同的标记和基类,改变修饰的class,可以在不同的样式间进行切换如".nav-pills"(胶囊式导航)与 ".nav-tabs&quo ...
- 若依单体Vue版本新增多环境配置
若依框架是一个简单的web后台管理脚手架,基于SpringBoot+Vue开发的.本次更改版本为3.8.7截止2023年8月14日,最新版本! 若依自带只有 application.yml 与 app ...
- 大数据之路Week10_day05 (Redis的安装与简单命令使用)
Redis 支持单机版和集群,下面的步骤是单机版安装步骤 redis3.0.0版本的安装包百度云链接: 链接:https://pan.baidu.com/s/1mb_SdU5hHlrmUkWN7Drx ...
- composer 指定php版本
需要指定php和composer的位置,然后再去执行composer命令 ## 指定PHP版本 指定composer 指定载入包 /usr/local/php7/bin/php composer /u ...
- oracle各种字符集修改
select * from v$nls_parameter会显示nls_characterset和nls_nchar_characterset的值 修改字符集nls_characterset和nls_ ...