一条sql 引起的 weblogic内存溢出 OutOfMemoryError:GetNewTLA

本文探讨了在项目运行中遇到的OutOfMemoryError:GetNewTLA错误,详细解析了该错误的原因,涉及JRockit JVM的特性,以及TLA(Thread Local Area)的配置与影响。通过调整TLA大小,有效预防了内存不足的问题,但也指出可能增加内存碎片的风险。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

前几天项目在运行过程中突然报错: OutOfMemoryError:GetNewTLAi,查看日志最后发现,一段SQL引起,select* from A where 1=1 + ,标签的参数为空sql 1=1条件全表查询最后引发OutOfMemoryError:GetNewTLA,解决sql的问题,我回头又看GetNewTLA这个错误,我是头一次看到,后来查找资料了解到,这个错误是经常发生在JRockit的JVM上的,如果都用hotspot或者J9的JVM可能不会遇到这个问题。
TLA 全称是thread local area,它是在heap或者nursery中分配的一个块空间,是thread在执行的时候自己说占用的,具体的配置参数有:
-XXtlaSize:min=,preferred= -XXlargeObjectLimit: -XXminBlockSize:
在weblogic server中,找到》服务器启动》》参数》》-XXtlaSize:min=128k,preferred=512k,wasteLimit=128k
-XXtlaSize 默认大小是2kB, minimum不能小于large object limit

一个thread可以将一下小的对象分配在TLA区,这些对象是不需要和其他thread进行同步的,然后TLA里分配的对象也可以是非thead本地,它可以被其他任何thread所访问,而且也会被GC.如果当前的TLA占满了,就会继续申请新TLA区空间。

TLA的大小会影响其使用和分配的效率和速度,同时会影响GC的发生频率。更大一点的TLA区会让thead可以分配更大的对象在TLA而减少申请新TLA的频率。

R27.2以后的版本是运行thread将非常大的对象保存在TLA的。也就是说,增加TLA的大小可以预防分配对象时内存不够的问题,但是会增加发生内存碎片的问题。在R27.1以后的版本中,TLA的大小是动态的依赖当前的空闲空间大型,变化范围在minimum和preferred大小之间。

增加TLA的大小对thread分配大对象的是有一定的好处。
增加TLA的最小值minimum可能会提高GC的次数。
参考:原文链接:https://blog.youkuaiyun.com/heqinghua217/article/details/51699106

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值