JVMTI内存申请日志采集

在这里插入图片描述
在这里插入图片描述

OOM内存溢出

Android中导致OOM的原因主要可以划分为以下几个类型:
在这里插入图片描述

动态内存分配监听

记录程序执行过程中的动态内存分配,当发生OOM或者发生性能问题时,就能够分析记录信息掌握内存使用情况。如:是否存在内存泄露、内存抖动、大对象等问题。

对象创建记录

ObjectAlloc|时间线程对象类型对象大小对象ID(TAG) 哪里创建(堆栈信息)

案例:
ObjectAlloc|TIME:1614847619390 THREAD:Thread-2 Class:Lcom/vance/jvmti/vance; Size:16 TAG:12777 Lcom/vance/jvmti/MainActivity$1;#run

对象回收记录
ObjectFree|TIME:1614847619545 TAG:12778

Application Performance Monitor (APM)应用性能监测软件

在这里插入图片描述

https://docs.oracle.com/javase/7/docs/platform/jvmti/jvmti.html

Java虚拟机工具接口,它可以监控 JVM 内部事件的执行,包括内存申请、线程创建、类加载、GC 信息、方法执行等;也可以控制 JVM 的某些行为。

在这里插入图片描述

https://source.android.google.cn/devices/tech/dalvik/art-ti#jvmti

日志方案记录

1、对产生的日志使用IO写入文件

在这里插入图片描述

突破DEBUG限制1

一般的在Android中使用Jvmti会使用Debug.attachJvmtiAgent来让虚拟机动态加载一个Jvmti Agent ,然后运行中能够触发JVM源生线程Attach Listener来执行这个Agen module的回调函数。

Debug.attachJvmtiAgent最后会调用到VMDebug.attachAgent中,VMDebug.attachAgent最终会调用到VMDebug_nativeAttachAgent中。

在这里插入图片描述

release启动时是关闭调试信息的,所以需要在调用VMDebug_nativeAttachAgent前开启调试能力。参考美团的方案可以调用SetJdwpAllowed来开启调试功能。
在这里插入图片描述

突破DEBUG限制2

完成了第一步操作之后,我们运行程序将得到以下错误:

在这里插入图片描述

根据日志信息很明显,在加载Agent的Agent_OnAttach函数要获取jvmti_env时候需要使用
ART_TI_VERSION_1_2(0x70010200)这个verison来获取,而不能用JVMTI_VERSION_1_2 (0x30010200)。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值