Flink on yarn任务内存调优

1、taskManager内存调优

flink taskmanager任务运行时的内存模型如下:

        可以看到flink taskmanager任务内存主要分为两大块,一个是flink框架和任务本身的内存,一个是jvm本身的内存开销。

1.1、yarn-pre-job模式

        taskmanager.memory.process.size 这个配置是配置flink taskmanager任务的总内存,里面各个区域的内存划分flink框架会根据默认比例进行划分,但有时候默认的划分并不能满足我们的需求,容易造成内存和计算资源浪费。

        下面将介绍flink taskmanagr各个组件的详细内存调优。taskmanager内存介绍可以参考这篇文章flink任务内存调优,TaskManager、JobManager内存配置_大数据摸鱼的博客-CSDN博客

        flink on yarn-pre-job任务提交参数如下:

flink run -t yarn-per-job \
-c com.Test \
-Dpipeline.name="flink test job" \
-Dyarn.application.name="flink test job" \
-Dtaskmanager.memory.process.size="2048m" \
-Dtaskmanager.memory.framework.heap.size="128m" \
-Dtaskmanager.memory.task.heap.size="640m" \
-Dtaskmanager.memory.managed.size="768m" \
-Dtaskmanager.memory.framework.off-heap.size="128m" \
-Dtaskmanager.memory.network.max="64m" \
-Dtaskmanager.memory.jvm-metaspace.size="128m" \
-Dtaskmanager.memory.jvm-overhead.max="192m" \
-Djobmanager.memory.process.size="700m" \
-Dclassloader.resolve-order="parent-first" \
-Dyarn.application.queue="other" \
-Dstate.checkpoints.dir="hdfs:///flink/checkpoints" \
/app/test.jar

参数说明:

taskmanager.memory.process.size        taskmanager总内存设置为2048m

taskmanager.memory.framework.heap.size        flink框架堆内存128m

taskmanager.memory.task.heap.size                用户代码运行堆内存640m

taskmanager.memory.managed.size                用于hash排序的内存768m

taskmanager.memory.framework.off-heap.size        flink框架本身堆外内存128m

taskmanager.memory.network.max                最大网络缓存内存64m

taskmanager.memory.jvm-metaspace.size                jvm内存128m

taskmanager.memory.jvm-overhead.max                 jvm最大内存192m

jobmanager.memory.process.size                        jobmanager内存设置为700m

1.2、yarn-application模式

        yarn-application内存参数调优基本和yarn-pre-job模式一样,只是yarn-application模式需要把用户的jar包传到hdfs上。其运行指令如下

flink run-application -t yarn-application \
-c com.Test \
-Dpipeline.name="flink test job" \
-Dyarn.application.name="flink test job" \
-Dtaskmanager.memory.process.size="2048m" \
-Dtaskmanager.memory.framework.heap.size="128m" \
-Dtaskmanager.memory.task.heap.size="640m" \
-Dtaskmanager.memory.managed.size="768m" \
-Dtaskmanager.memory.framework.off-heap.size="128m" \
-Dtaskmanager.memory.network.max="64m" \
-Dtaskmanager.memory.jvm-metaspace.size="128m" \
-Dtaskmanager.memory.jvm-overhead.max="192m" \
-Djobmanager.memory.process.size="700m" \
-Dclassloader.resolve-order="parent-first" \
-Dyarn.application.queue="other" \
-Dstate.checkpoints.dir="hdfs:///flink/checkpoints" \
hdfs:///app/test.jar

 

 

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

大数据动物园

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值