Job提交流程和切片源码详解(****)

1)job提交流程源码详解

waitForCompletion()

submit();

// 1建立连接

connect();

// 1)创建提交job的代理

new Cluster(getConfiguration());

// (1)判断是本地yarn还是远程

initialize(jobTrackAddr, conf);

// 2 提交job

submitter.submitJobInternal(Job.this, cluster)

// 1)创建给集群提交数据的Stag路径

Path jobStagingArea = JobSubmissionFiles.getStagingDir(cluster, conf);

// 2)获取jobid ,并创建job路径

JobID jobId = submitClient.getNewJobID();

// 3)拷贝jar包到集群

copyAndConfigureFiles(job, submitJobDir);

rUploader.uploadFiles(job, jobSubmitDir);

// 4)计算切片,生成切片规划文件

writeSplits(job, submitJobDir);

maps = writeNewSplits(job, jobSubmitDir);

input.getSplits(job);

// 5)向Stag路径写xml配置文件

writeConf(conf, submitJobFile);

conf.writeXml(out);

// 6)提交job,返回提交状态

status = submitClient.submitJob(jobId, submitJobDir.toString(), job.getCredentials());

2)FileInputFormat源码解析(input.getSplits(job))

(1)找到你数据存储的目录。

(2)开始遍历处理(规划切片)目录下的每一个文件

(3)遍历第一个文件ss.txt

a)获取文件大小fs.sizeOf(ss.txt);

b)计算切片大小computeSliteSize(Math.max(minSize,Math.min(maxSize,blocksize)))=blocksize=128M

c)默认情况下,切片大小=blocksize

d)开始切,形成第1个切片:ss.txt—0:128M 第2个切片ss.txt—128:256M 第3个切片ss.txt—256M:300M(每次切片时,都要判断切完剩下的部分是否大于块的1.1倍,不大于1.1倍就划分一块切片

e)将切片信息写到一个切片规划文件中

f)整个切片的核心过程在getSplit()方法中完成。

g)数据切片只是在逻辑上对输入数据进行分片,并不会再磁盘上将其切分成分片进行存储。InputSplit只记录了分片的元数据信息,比如起始位置、长度以及所在的节点列表等。

h)注意:block是HDFS物理上存储的数据,切片是对数据逻辑上的划分。

(4)提交切片规划文件yarn上yarn上MrAppMaster可以根据切片规划文件计算开启maptask个数。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
xxl-job 是一款开源的分布式任务调度框架,可以实现对任务的调度、执行和监控等功能。下面是对 xxl-job 源码的一些简要解析: 1. 源码结构:xxl-job 源码分为 admin 模块和 executor 模块。admin 模块是任务调度中心,负责任务的管理和调度;executor 模块是任务执行器,负责实际执行任务。 2. 任务调度中心:admin 模块包含了任务的增删改查、任务的调度和执行监控等功能。其中,调度功能主要包括创建调度任务、分配执行器、触发执行等操作;执行监控功能则是实时监控任务的执行状态、日志等信息。 3. 任务执行器:executor 模块主要负责接收任务调度中心的任务分配,并执行具体的任务逻辑。执行器通过与调度中心建立长连接,接收调度中心的指令,并根据指令执行相应的任务。 4. 分布式调度:xxl-job 支持分布式部署,可以通过配置多个调度中心和执行器来实现任务的高可用和负载均衡。调度中心之间采用 ZooKeeper 进行注册和发现,执行器之间采用 Netty 进行通信。 5. 源码扩展:xxl-job 源码提供了丰富的扩展点,可以根据需求进行二次开发。例如,可以通过实现自定义的任务执行器、任务拦截器等来满足特定的业务需求。 总的来说,xxl-job 源码通过任务调度中心和任务执行器的协作,实现了分布式任务的调度和执行。它具有良好的可扩展性和可靠性,适用于各种复杂的定时任务场景。如需详细了解源码,建议直接查看官方文档和源码仓库。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值