首页 > 其他分享 >七、Hadoop优化

七、Hadoop优化

时间:2023-12-04 20:56:33浏览次数:30  
标签:map task join 作业 reduce Hadoop 任务 优化

优化1:Combiner

使用之前

 

 

使用之后

 

 

减少的了reduce 从map拉取数据的过程,提高计算效率。

hadoop 的计算特点:将计算任务向数据靠拢,而不是将数据向计算靠拢。

特点:数据本地化,减少网络io。

首先需要知道,hadoop数据本地化是指的map任务,reduce任务并不具备数据本地化特征。 通常输入的数据首先在逻辑上注意这里不是真正物理上划分)将会分片split,每个分片上构建一个map任务,由该任务执行执行用户自定义的map函数,从而处理分片中的每条记录。 那么切片的大小一般是趋向一个HDFS的block块的大小。为什么最佳的分片大小是趋向block块的大小呢?是因为这样能够确保单节点上最大输入块的大小,如果分片跨越两个数据块,没有一个block能够同时存储这两块数据,因此需要通过网络传输将部分数据传输到map任务节点上。这样明显比使用本地数据的map效率更低。 注意,map任务执行后的结果并没有写到HDFS中,而是作为中间结果存储到本地硬盘,那为什么没有存储到HDFS呢?因为,该中间结果会被reduce处理后产生最终结果后,该中间数据会被删除,如果存储到HDFS中,他会进行备份,这样明显没有意义。如果map将中间结果传输到reduce过程中出现了错误,Hadoop会在另一个节点上重新执行map产生中间结果。 那么为什么reduce没有数据本地化的特点呢?对于单个reduce任务来说,他的输入通常是所有mapper经过排序输出,这些输出通过网络传输到reduce节点,数据在reduce节点合并然后由reduce函数进行处理。最终结果输出到HDFS上。当多个有reduce任务的时候,map会针对输出进行分区partition,也就是为每个reduce构建一个分区,分区是由用户指定的partition函数,效率很高。 同时为了高效传输可以指定combiner函数,他的作用就是,减少网络传输和本地传输

combine操作只适合等幂操作

 

假设文件是500mb

注意:将reduce端的聚合操作,放到map 进行执行。适合求和,计数,等一些等幂操作。不适合求平均值,次幂等类似操作

 

优化2:Join(数据倾斜)

MapReduce中的join

  其实就是类似于关系型数据库中的连接查询一样。需要计算的数据可能存储在不同的文件中或不同表中,两个文件又有一些相同的字段可以相互关联,这时候我们就可以通过这些关联字段将两个文件中的数据组合到一起进行计算了。

  我知道的mr有三种join方式。Map join、SemiJoin、reduce join。

Reduce Join(我们之前做的代码连接就是这个方式)

思路:

  分为两个阶段

   (1)map函数主要是对不同文件中的数据打标签。

  (2)reduce函数获取key相同的value list,进行笛卡尔积。

Map Join思路:

  比如有两个表,有一个表非常大,而另一个表非常小,以至于小表可以直接存放到内存中。这样,我们可以将小表复制多份,让每个map task内存中保存一个hash map,将小表数据放入这个hash map中,key是小表与大表的内个连接字段,value是小表一条记录,然后只扫描大表:对于大表中的每一条记录key/value,在hash map中查找是否有相同的key的记录,如果有,则连接输出即可。

Semi Join 这个SemiJoin其实就是对reduce join的一种优化。

  就是在map端过滤掉不参加join操作的数据,则可以大大减少数据量,提高网络传输速度。

这三种join方式适用于不同的场景:

  Reduce join要考虑数据量过大时的网络传输问题。

  Map join和SemiJoin则要考虑数据量过大时的内存问题。 如果只考虑网络传输,忽略内存问题则。

  Map join效率最高,其次是SemiJoin,最低的是reduce join。

DistributedCache DistributedCache是Hadoop提供的文件缓存工具,它能够自动将指定的文件分发到各个节点上,缓存到本地,供用户程序读取使用。一般用户数据字典的分发,和map join使用。一般缓存的文件都是只读。

 

优化3:根据实际情况调整切片大小

为什么默认切片是128MB和blk大小一致?(优化)

1 切片大小默认一致,是为了数据本地化,减少数据拉取消耗网络io

2 并不是越大越好,也不是越小越好。根据集群的资源情况而定。

当集群计算资源充足的情况下:将切片的大小调小,增加map数量,提高读取效率。调节 maxsize

当集群计算资源紧张的情况下:将切片的大小调大,减少资源占用,让任务正常运转。 调节 minsize

mapred.min.split.size、mapred.max.split.size、blockSize

mapreduce.input.fileinputformat.split.maxsize

mapreduce.input.fileinputformat.split.minsize

 

 

 

优化4:可以设置yarn资源和队列。

mr运行日志信息:百分比是按照完成的m或r的任务的个数/m或r的总个数。

MRv1/MRv2/YARN MRv1:

  对于经典的MRv1它由三部分组成 :

    编程模型、 数据处理引擎和运行时环境。

    编程模型由新旧 API 两部分组成,新旧api只是代码封装上略有变化,性能没变化。

    数据处理引擎由 MapTask 和 ReduceTask 组成。 运行时环境由 JobTracker 和 TaskTracker 两类服务组成。

  MRv2:

    由于MRv1对JobTracker的功能过多造成负载过重在扩展性、 资源利用率和多框架支持等方面存在不足,因此MRv2框架 的基本设计思想是将MRv1中的JobTracker包含的资源管理和应用管理两部分功能进行拆分,分别交给两个进程实现。 资源管理进程与具体应用程序无关,它负责整个集群的资源管理(内存、 CPU、 磁盘)。 应用管理进程负责管理应用程序,并且每个应用管理进程只管理一个作业。 由于资源管理可以共享给其他框架使用,因此MRv2将其做成了一个通用的系统YARN,YARN系统使得MRv2计算框架在可扩展性,资源利用率,多框架支持方面得到了很大改进。

  YARN:yarn由4部分组成。

  1. ResourceManager主要功能是:

      (1)接收用户请求

      (2)管理调度资源

      (3)启动管理am    

      (4)管理所有nm,处理nm的状态汇报,向nm下达命令。

 2.Container:yarn的应用都是运行在容器上的,容器包含cpu,内存等信息。

 3.NodeManager:NM是每个节点上的资源和任务管理器,它会定时地向RM汇报本节点上的资源使用情况和各个容器的运行状态;同时负责对容器的启动和停止。

  1. ApplicationMaster:管理应用程序。向RM获取资源、为应用程序分配任务、 监控所有任务运行状态。

  2. 作业提交

  首先我们将任务提交给JobClient,JobClient会向RM获取一个appId。 然后我们的JobClient会对作业进行处理, 切分InputSplit, 将作业的Jar包, 配置文件和拷贝InputSplit信息拷贝到HDFS。 最后, 通过调用RM的submitApplication()来提交作业。

  1. 作业初始化

  当RM收到submitApplciation()的请求时, 就将该请求发给调度器, 调度器分配第一个容器, 然后RM在该容器内启动ApplicationMaster进程。该进程上运行着一个MRAppMaster的Java应用。其通过创造一些bookkeeping对象来监控作业的进度。 然后通过hdfs得到由JobClient已经处理好的作业信息。为每个Inputsplit创建一个map任务, 并创建相应的reduce任务。然后ApplicationMaster会对整个作业量进行判断,如果作业量很小, ApplicationMaster会选择在其自己的JVM中运行任务, 这种作业称作是uber task的方式。在任务运行之前, 作业的setup方法被调用来创建输出路径。

  1. 任务分配

  如果不是小作业, 那么ApplicationMaster向RM请求更多的容器来运行所有的map和reduce任务,每个容器只能对应一个任务。这些请求是通过心跳来传输的, 包括每个map任务的数据位置, 比如Inputsplit的主机名和机架。调度器利用这些信息来调度任务, 尽量将任务分配给有存储数据的节点, 或者分配给和存放Inputsplit的节点相同机架的节点。

  1. 任务运行

  当一个任务由RM的调度器分配了一个容器后, ApplicationMaster与NM通信来启动容器。任务由一个为YarnChild的Java应用执行。在运行任务之前首先本地化任务需要的资源, 比如作业配置, JAR文件, 以及hdfs中保存的任务所需的所有文件。最后, map任务或者reduce运行在一个叫YarnChild的进程当中。

  1. 进度和状态更新

  每个NM会向applicationmaster汇报自己的工作状态,JobClient会每秒轮询检测applicationmaster,这样就能随时收到更新信息。

  1. 作业完成

  除了向applicationmaster请求作业进度外, JobClient每5分钟都会通过调用waitForCompletion()来检查作业是否完成。作业完成之后,applicationmaster和NM会清理工作状态, OutputCommiter的作业清理方法也会被调用. 作业的信息会被作业历史服务器存储以备之后用户核查.

yarn对异常task的处理(推测执行)?(重要!!!)

  推测执行是在分布式环境下,因为某种原因造成同一个job的多个task运行速度不一致,有的task运行速度明显慢于其他task,则这些task拖慢了整个job的执行进度,为了避免这种情况发生,Hadoop会为该task启动备份任务,让该speculative task与原始task同时处理一份数据,哪个先运行完,则将谁的结果作为最终结果。推测执行优化机制采用了典型的以空间换时间的优化策略,它同时启动多个相同task(备份任务)处理相同的数据块,哪个完成的早,则采用哪个task的结果,这样可防止拖后腿Task任务出现,进而提高作业计算速度,但是,这样却会占用更多的资源。

yarn调度器的策略?(重要!!!)

  yarn默认是计算能力调度 FifoScheduler:根据先进先出排队,最简单的调度器。 FIFO

CapacityScheduler(计算能力调度)、FairScheduler(公平调度):

  相同点:

    (1)都是队列。

    (2)都有资源最大最小上线限制。

    (3)都是资源共享,每个队列剩余的资源可以给其他队列使用。

  不同点:

    (1)队列排序算法不同:计算能力调度资源使用量小的优先。公平调度根据公平排序算法排序。

    (2)应该用选择算法不同:计算能力调度是先进先出。公平调度先进先出或者公平排序算法。

    (3)资源抢占:公平调度如果当前队列有新应用提交后,会把共享出去的资源抢夺回来。

 

常见面试题:hadoop不适合存储小文件?为什么?

1、从HDFS角度分析:不适合存储小文件,因为每一个小文件都会产生一个元数据,而元数据是存储在NameNode中的,NN内存是有限的,如果小文件过多可能会导致NN宕机

2、从MR角度分析:不适合存储小文件,因为每一个小文件都会占用一个block块,除最后两个block块由一个切片处理,而其他每一个block块都会产生一个切片,会导致map的数量会很多,而生成map任务也是需要资源的。可能会导致Map阶段失败。

解决思路: 小文件能合并就合并。

 

标签:map,task,join,作业,reduce,Hadoop,任务,优化
From: https://www.cnblogs.com/SIKE231310/p/17875933.html

相关文章

  • 小程序性能优化:深入探讨启动耗时的调优策略
    在移动应用开发中,用户对于程序启动速度的要求越来越高。在小程序开发中,启动耗时是一个关键指标,直接影响用户体验。本文将深入探讨小程序启动耗时的优化方法,并提供详细的代码演示,以帮助开发者提高小程序的性能。1.启动耗时的定义启动耗时是指从用户点击小程序图标到小程序完全加载......
  • SEO与SEM的区别:搜索引擎优化与搜索引擎营销
    随着互联网的发展,搜索引擎成为人们获取信息、产品和服务的主要途径。为了在竞争激烈的在线市场中脱颖而出,企业需要关注搜索引擎优化(SEO)和搜索引擎营销(SEM)。虽然SEO和SEM都与提升网站在搜索引擎中的可见性有关,但它们之间存在一些关键的区别。1.定义和目标:SEO是通过优化网站结构、内......
  • 如何选择正确的关键词进行SEO优化
    在进行SEO优化时,选择正确的关键词是至关重要的一步。本文将为您介绍一些有效的方法和技巧,帮助您选择最合适的关键词来提升网站的搜索引擎排名。1.确定网站主题:首先,明确您网站的主题和定位。了解自己网站所提供的核心内容和服务,这有助于确定与之相关的关键词。2.目标受众分析:了解您......
  • 如何利用图像优化提升SEO效果
    除了文字内容,图像也是网站SEO优化中的重要元素。本文将为您介绍一些有效的方法和技巧,帮助您利用图像优化来提升网站的搜索引擎排名和用户体验。1.使用高质量的图片:首先,选择高质量、高清晰度的图片可以增加用户的阅读体验和网站的专业感。同时,高质量的图片也有助于提高搜索引擎的识......
  • Tita升级 | OKR 列表优化
    升级详情:Tita-OKR和新绩效一体化管理平台1.OKR列表支持快速添加项目和任务Q1:如何添加项目和任务?小T:OKR参与者,可以在OKR列表上添加项目和任务,包括“添加任务”、“关联任务”以及“添加项目”和“关联项目”的操作。此外,还可以在OKR列表页直接删除KR哦~2.OKR列表支......
  • 掌握CRM,优化企业销售管理的关键
     CRM系统是客户关系管理系统的缩写。现代企业利用网络技术协调企业和客户之间在销售和服务上的对接,提升企业核心竞争力的一种手段。那么CRM管理系统一般包含哪些功能模块呢?今天小编为大家介绍一下。一、好的CRM管理系统有哪些功能特性1、有全方位的客户视图和客户分析模块。......
  • 细说GaussDB(DWS)的2种查询优化技术
    本文分享自华为云社区《GaussDB(DWS)查询优化技术大揭秘》,作者:胡辣汤。大数据时代,数据量呈爆发式增长,经常面临百亿、千亿数据查询场景,当数据仓库数据量较大、SQL语句执行效率低时,数据仓库性能会受到影响。本期《GaussDB(DWS)查询优化技术大揭秘》的主题直播中,我们邀请到华为云Ga......
  • 解密Prompt系列20. LLM Agent之再谈RAG的召回多样性优化
    几个月前我们就聊过RAG的经典方案解密Prompt系列14.LLMAgent之搜索应用设计。前几天刚看完openAI在DevDay闭门会议上介绍的RAG相关的经验,有些新的感悟,借此机会再梳理下RAG相关的优化方案。推荐直接看原视频(外网)ASurveyofTechniquesforMaximizingLLMPerformanceRAG最关键......
  • centos7.5 hadoop NAT 静态IP网络环境搭建
    1设置VMware网络环境1.选择VMNet8并将子网IP修改为192.168.10.0,保证集群ip都在这个网段下2.选择NAT设置,配置NAT的网关为192.168.10.22设置windows11网络环境1.打开控制面板\网络和Internet\网络连接,选择VMnet8,右键选择属性2.双击Internet协议版......
  • SQLServer数据库优化学习-总结
    SQLServer数据库优化学习-总结背景各种能力都需要提升.最近总是遇到SQLServer的问题趁着周末进行一下学习与提高.安装与优化1.数据库必须安装64位,不要安装成32位的版本2.数据库的序列号要使用enterprisecore的版本,不要使用enterprise的版本,仅可能使用20个......