Java进程堆外内存(off heap)大小

本文探讨了Java中使用ByteBuffer.allocateDirect进行堆外内存(off heap)的分配,包括如何在本地和远程进程中查看此类内存的大小。通过JVisualVM的MBeans插件和JMX进行监控。此外,还提及了利用Unsafe反射调用直接申请堆外内存的情况,但这种内存通常无法通过Java直接获取,可能需要借助如gperftools等外部工具进行分析。
摘要由CSDN通过智能技术生成

一、使用ByteBuffer.allocateDirect分配的off heap内存大小

本机进程

  • 在Jvisualvm中安装 Mbeans插件,然后查看java.nio/BufferPool/direct
    这里写图片描述

  • 进程内使用代码获取

MBeanServer mbs = ManagementFactory. getPlatformMBeanServer() ;
ObjectName objectName = new ObjectName("java.nio:type=BufferPool,name=direct" ) ;
MBeanInfo info = mbs.getMBeanInfo(objectName) ;
for(MBeanAttributeInfo i : info.getAttributes()) {
    System.out .println(i.getName() + ":" + mbs.getAttribute(objectName , i.getName()));
}

远程进程

  • JMX获取
    如果目标机器没有启动JMX,那么添加jvm参数:<
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值