修改jvm对象的属性值(私有)

修改jvm对象的属性值(私有)

这个想法的来源

一个spark job 在启动之后,就会确定 executor 的数量。但是存在一种情况,当我的队列资源宽松

可能就要调整一些job的资源,但是spark job在启动的时候,最大的资源就确定了,所以能否可以通过直接修改jvm

里面某些属性值来调整 job 的 资源使用大小。

通过阅读 spark on yarn 的 提交job流程代码,发现在 ApplicationMaster registerAM 方法最后

会启动一个 线程:

  1. 主要用来监控 失败 exetors 数量,失败超过一定数据之后,执行 spark stop操作
  2. 执行 allocator.allocateResources() 方法,这个方法里面会比较 executor 设定值 (targetNumExecutors) 与 当前已经分配的值,不够的话,则会
    执行申请操作
    那么如果直接增加 jvm YarnAllocator 实例的 targetNumExecutors的话, 这个spark job executor 数据就会增加。

具体操作 通过 arthas 工具操作,修改对象的私有属性值

  1. 找到 spark driver 所在的主机 执行 java -jar arthas-boot.jar

  2. 选择 对应的 进程

  3. 先找到 此对象的 classloader

    sc -d *YarnAllocator

  4. 使用 vmtool 工具 修改 私有的对象属性

    vmtool --action getInstances --className org.apache.spark.deploy.yarn.YarnAllocator //先获取到所有的实例对象
    vmtool --action getInstances --className org.apache.spark.deploy.yarn.YarnAllocator --express '#instance=instances[0]' //再拿到第一个实例对象
    vmtool --action getInstances --className org.apache.spark.deploy.yarn.YarnAllocator --express '#instance=instances[0],#fieldObj=@org.apache.spark.deploy.yarn.YarnAllocator@class.getDeclaredField("orgapachesparkdeployyarnYarnAllocatortargetNumExecutors")' //反射拿到字段 vmtool --action getInstances --className org.apache.spark.deploy.yarn.YarnAllocator --express '#instance=instances[0],#fieldObj=@org.apache.spark.deploy.yarn.YarnAllocator@class.getDeclaredField("orgapachesparkdeployyarnYarnAllocator$$targetNumExecutors"),#fieldObj.setAccessible(true)' //字段设置可访问
    vmtool --action getInstances --className org.apache.spark.deploy.yarn.YarnAllocator --express '#instance=instances[0],#fieldObj=@org.apache.spark.deploy.yarn.YarnAllocator@class.getDeclaredField("orgapachesparkdeployyarnYarnAllocatortargetNumExecutors"),#fieldObj.setAccessible(true),#fieldObj.get(#instance)' //获取到实例的私有属性值 vmtool --action getInstances --className org.apache.spark.deploy.yarn.YarnAllocator --express '#instance=instances[0],#fieldObj=@org.apache.spark.deploy.yarn.YarnAllocator@class.getDeclaredField("orgapachesparkdeployyarnYarnAllocator$$targetNumExecutors"),#fieldObj.setAccessible(true),#fieldObj.set(#instance, 5)' //设置实例的私有属性值

注意: 有些复杂的属性不好确定,此时就需要 反编译代码了,或者使用 vmtool express 里面通过反射 打印出 所有的 Filed class.getDeclaredFields()

jad org.apache.spark.deploy.yarn.YarnAllocator //找到 targetNumExecutors 属性,可以看到并不是 targetNumExecutors,而是 orgapachesparkdeployyarnYarnAllocator$targetNumExecutors

  1. 观察 yarn web ui ,查看这个 job 的资源是不是增加了

具体操作 通过 arthas 工具操作,查看对象的静态属性值、执行静态方法

复制代码
ognl -c 279f2327 @org.apache.spark.deploy.yarn.YarnAllocator@MEM_REGEX 
ognl -c 279f2327 @org.apache.spark.deploy.yarn.YarnAllocator@MEM_REGEX() 
相关推荐
落花流水 丶5 小时前
Spring Security 完全指南
java·spring
Elastic 中国社区官方博客6 小时前
易捷问数(NewmindExAI)平台解决 ES 升级后 AI 助手与 Attack Discovery 不正常问题
大数据·运维·数据库·人工智能·elasticsearch·搜索引擎·ai
PRINT!6 小时前
RabbitMQ实战项目(含代码仓库地址+视频教程地址)基本篇已更新完结,高级篇持续更新中
java·分布式·后端·微服务·rabbitmq
gAlAxy...6 小时前
MyBatis-Plus 核心 CRUD 操作全解析:BaseMapper 与通用 Service 实战
java·开发语言·mybatis
开开心心就好7 小时前
一键加密隐藏视频,专属格式播放工具
java·linux·开发语言·网络·人工智能·macos
Amarantine、沐风倩✨7 小时前
列表接口严禁嵌套 LISTAGG + REGEXP:一次 mission_label 性能事故复盘
java·数据库·sql
m***06687 小时前
Java进阶(ElasticSearch的安装与使用)
java·elasticsearch·jenkins
Anastasiozzzz7 小时前
Java异步编程:CompletableFuture从入门到底层实现
java·开发语言
xiaomin-Michael8 小时前
netty学习
java
上海合宙LuatOS8 小时前
LuatOS核心库API——【fft 】 快速傅里叶变换
java·前端·人工智能·单片机·嵌入式硬件·物联网·机器学习