Chapter 7. 剖析 MapReduce 在 Yarn 中的调度细节

本文为 《Hadoop The Definitive Guide 4th Edition》的读书笔记,仅限交流使用。

剖析 MapReuce Job 的运行

我们能够在 JOb 对象上调用一个submit()方法来运行一个 MapReduce job,你也能调用 waitFormCompletion() -- 总是提交一了一个job后等待job的完成。这个方法隐藏了许多的执行细节。我们现在开看看他底层运行的步骤:
完整的运行流程见 Figure 7-1 :

  • 客户端提交 MapReduce job
  • YARN 资源管理器里,在集群里定位计算资源在哪个节点上开辟的。
  • YARN node manager 中,运行在并且管理在集群机器上的计算容器,每一个容器有自己的nodeManager。
  • MapReduce 应用程序管理员(master),定位 MapReduce job 的 task 手下们。应用程序 master 和 MapReduce task 运行在 由资源管理器调度、由 node manager 管理 的 containers 中,
  • 分布式文件系统,用于在其他实体中分享 job 文件。
Filgure 7-1.png

Job 提交过程

submit() 方法在 Job 上创建了一个内置的 JobSubmitter 实例化并且调用 submitJobInternal() 方法。 当调用了一个job, waitForCompletion() 将会每一秒去检测job的运行,当运行成功后,就展示出 job counters。如果因为job任务有错误而失败了,也会打印在控制台上。

job的提交过程是通过 JobSubmitter 来实现的:

  • 向 resource manager 请求一个新的 应用程序 ID,使用在 MapReduce job 的ID上 (第2步)。
  • 检查job指定的输出路径,如果路径没有指定或者已经存在,job就不会被提交,并且会向 MapReduce 抛出一个 error.
  • 计算job的 input splits 。 如果无法计算splits(比如文件不存在),job就不会被提交,并且会向 MapReduce 抛出一个 error.
  • 拷贝 job 所需要的资源,包括job的jar包,配置文件,计算后的 input splits,送给在共享文件系统中使用job的ID来命名的目录中(第3步)。 job 的jar包会根据配置的备份数来进行备份,默认是10.这样就可以有许多的拷贝在集群中传输给 node manager去读取,好为job运行 task。
  • 通过调用在 resource manager 上调用 submitApplication()来提交任务(第4步)。

Job 初始化

当 resource manager 接到了 submitApplication() 方法的调用,他就将请求转送给 YARN 调度器。调度器就分配一个容器,随后 resource manager 开始启动在nodemanager的管理下的应用程序 master的进程(5a 5b)。

Mapreduce job的应用程序master是一个主类为 MRAPPMaster 的Java应用程序。他通过创建一些 bookkeeping(清单,账本)来初始化job,它用来追踪job的运行,也会接收从task发来的关于task 运行 和 完成 的报告(第6步)。然后,他从分享的文件系统中检索在客户端中计算好的 input splits(第7步)。然后就在每一个 split 上创建一个 map task,而 reduce task 对象的数目根据

mapreduce.job.reduces

属性来设定。
或者

setNumReduceTasks() 

方法来设定。

task的ID在此时就被给予。

应用程序 master 必须决定怎样运行由 MapReduce 生成的 task 。如果 job 很小,应用程序 master 可能在他自己运行所在的 JVM 上运行这个 job。 这是通过比较分配和运行一个新的容器并且不得不并行运行的他们的开销和在一个node一个队列中运行他们的开销,来判断。使用这种方式运行的 task 叫 最好的(uber)task。

少于10个mapper和只有一个reducer,并且输入数据小于块大小的job就叫做一个小job(uber),允许使用uber方式运行。这些界线可以使用下面两个属性来设置:

mapreduce.job.ubertask.maxmaps
mapreduce.job.ubertask.maxreduces
mapreduce.job.ubertask.maxbytes

Uber task 必须要激活,即将属性

mapreduce.job.ubertask.enable

设置为 true

最后,在任何一个 task 能够运行之前,应用程序 master 就调用OutputCommitter 的 setupJob() 方法。默认的是 FileOutputCommitter,他会为整个job创建一个不可修改的输出路径,而为task输出创建一个临时的工作目录。详细有空讲。

task assignment 任务分配

如果一个 job 没有资格作为一个uber task运行,那么应用程序 master 将为一个job中所有的map和reduce task请求容器(第8步)。

为 map tasks 的所发出的请求会先进行,因为map tasks的优先级比 redeuce tasks 高很多,所以在 reduce 的排序阶段开始之前,必须要等他之前的 map task们 运行结束。在map tasks 完成了5%后,AppMaster 才能为 reduce task 发出资源(向 resource manager)请求。

reduce 能运行在集群的任何地方。但是需要 应用程序master 为 map tasks 发送的请求要遵守由调度器努力维持的数据本地化约束。

  • task是数据本地化的,即 task 和 split 在一个 node 上。
  • task 与 split 是在同一个的机架上,但不在一个node中。
  • 一些 task 和他的 split 也有可能是在不同的机架中。

对于分布式的运行,通过查看job的counters,你能够查明运行在各个 本地化水平(上面三者)上的数目。

请求也会为task指定内存需求和CPU数目。默认的每一个map和reduce任务被分配有1024MB内存个一个虚拟CPU内核。这些值当然可以设置:

mapreduce.map.memory.mb
mapreduce.reduce.memory.mb
mapreduce.map.cpu.vcores
mapreduce.map.cpu.vcores

Task Execution 任务执行

一旦为一个 task 通过resource manager的调度器在分离节点上的容器上分配好了资源。应用程序 master 就开始联系 node manager,让他去启动容器(9a,9b)。task 是通过一个叫做 YarnChild 的主类Java应用程序执行的。在执行 task 之前,他会去定位 task 需要的资源,包括 job 配置文件,jar包和任何在分布式缓存中的文件(第10步)。最后,就开始运行 map task 或者 reduce task(第11步)。

YarnChild 需要专用的 JVM,以至于由用户编写定义map和reduce上的bug,不会影响到 node manager 的运行,造成崩溃或者中止。

流运行特殊的map和reduce task 为了运行用户自己的可执行程序并且与之交互。

流通过使用标准输入和标准输出与程序(可能使用其他程序编写的)进行交互,在执行 task 之间,Java程序将输入键值对送进额外的程序中,然后使用用户自定义的map或者reduce 方法处理输入,然后把输出键值对送回Java程序中。在 node manager 的立场上,他并不知道是一个子程序自己运行的map或reduce代码。

Figure 7-2

程序和状态更新

MapReduce job 是一个长期运行的并行批处理 job,运行时间由几秒到几小时。因为job的运行时间很重要,得到job执行时的反馈对用来说是非常重要的。一个 job 和他的每一个 task 都有一个 status(状态),包括job或者task的执行状态(比如:正运行,成功,完成,失败),还有 map 和 reduce 的完成进度,job conunter 的值,一个状态消息或者描述(可能用户代码设置的)。这些状态在job的执行过程中会不断的变化。

当 task 正运行,task能够计算他自身处理的进度(完成百分比)。对于 map task 来说,就是输入被处理的比例。 对于 reduce task, 就复杂了点,但是系统仍然会有输入进度的比例。他是将整个进度分成三个部分,对应于 shuffle 的三个阶段。比如,copy 和 sort 阶段(每一个占 1/3)已经都完成,而 task 的输入阶段完成了一半,那 task 的当前完成的进度就是 5/6 (1/3 + 1/3 + 1/3 * 1/2 = 5/6)。

task 中还会有许多的计数器(counter)去记录任务的运行情况,有些是框架中自带内建的,就像 ma 输出的记录数,当然用户能够自定义一个计数器。

当 map 和 reduce 正在运行的时候, 子进程会与他们的爸爸 AppMater 通过 umbilical ()接口进行交互。 task 汇报他的完成程度和状态信息给 appMaster,然后据聚合成 job 的运行视图。每三秒汇报一次。

resourse manager 网页界面将会展示出所有正在运行的 应用程序,是通过连接界面和 应用程序master 来得到的信息。

在Job 运行期间,客户端会通过每秒的轮询获得 应用程序master 中记录最近的状态信息(通过 mapreduce.client.progressmonitor.pollinterval来设置)。客户端也能够使用 Job 的 getStatus() 来获得包含了所有状态信息的JobStatus对象。

Figure 7-3

Job 完成

当 应用程序master 收到最后一个 task 发来的通知,说明最后一个 task 已经完成,他就将job的状态改为“成功”。当 Job(类)查询到这个状态,他就知道了这个 job 已经完成,然后他就打印一条信息给用户,并且返回 waitForCompletion() 方法。最后Job的统计数据与计数会打印到控制台输出。

最后, 应用程序master 和 task容器 清理他的工作状态(所以中间文件也会被删除),然后 OutputCommitter 的 commitJob() 方法被调用。 Job 的信息被归档在历史job服务中,以备用户去查看。

恩,就这些。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 196,099评论 5 462
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 82,473评论 2 373
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 143,229评论 0 325
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 52,570评论 1 267
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 61,427评论 5 358
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 46,335评论 1 273
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 36,737评论 3 386
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 35,392评论 0 254
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 39,693评论 1 294
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 34,730评论 2 312
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 36,512评论 1 326
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 32,349评论 3 314
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 37,750评论 3 299
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,017评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 30,290评论 1 251
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 41,706评论 2 342
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 40,904评论 2 335

推荐阅读更多精彩内容