Flink web.upload.dir

探讨Flink中常被忽略的web.upload.dir参数,解释其默认行为及潜在问题,尤其是在JobManager切换时可能导致的jar包丢失。文章提出通过NFS挂载共享目录作为解决方案,确保在高可用环境下,无论JobManager如何变化,上传的包始终可见。

好像很少有人谈论这个参数,基本被忽略了,这个参数是Flink少数不能设置为HDFS的参数,默认的web.upload.dir是在web.tmpdir目录下。以下是官方给出的2个参数的含义:

web.tmpdir
System.getProperty("java.io.tmpdir")	Flink web directory which is used by the webmonitor.
web.upload.dir
(none)	Directory for uploading the job jars. If not specified a dynamic directory will be used under the directory specified by JOB_MANAGER_WEB_TMPDIR_KEY.

放在tmp目录先肯定是有问题,一旦机器重启,可能所有上传的包都丢失了。你可能会修改这个参数为一个永久目录,即使如此还是有问题,今天就是谈论这个问题。

web.upload.dir既然不是HDFS共享目录,那就肯定是本地目录了,这个本地目录根据你的job manager是哪一台机器,就上传到哪一台机器的web.upload.dir. 

按照上面的推测,一旦发生job manager切换,那之前你上传的包,在新的job manager上是看不到的。这可不是我们想要看到的结果。如果你使用的是yarn-session.sh启动模式,所有的node manager都有可能是job manager. 如果你用standalone HA同样道理,一旦切换上传的包就看不到了。

解决这个问题用NFS比较好,这样所有的job maanager挂载这个目录,不管你怎么切换,都能看到web.upload.dir里的包。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

tom_fans

谢谢打赏

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

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

打赏作者

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

抵扣说明:

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

余额充值