Hadoop场景案例参数调优

news/2024/5/20 4:51:57 标签: hadoop, 大数据, hdfs

目录

1 需求

2 HDFS参数调优

hadoop-env.sh-toc" style="margin-left:80px;">(1)修改:hadoop-env.sh

hdfs-site.xml-toc" style="margin-left:80px;">(2)修改hdfs-site.xml

(3)修改core-site.xml

(4)分发配置

3 MapReduce参数调优

(1)修改mapred-site.xml

(2)分发配置

4 Yarn参数调优

(1)修改yarn-site.xml配置参数如下

(2)分发配置

5 执行程序

(1)重启集群

(2)执行WordCount程序

(3)观察Yarn任务执行页面


1 需求

(1)需求:从1G数据中,统计每个单词出现次数。服务器3台,每台配置4G内存,4核CPU,4线程。

(2)需求分析:

1G / 128m = 8个MapTask;1个ReduceTask;1个mrAppMaster

平均每个节点运行10个 / 3台 ≈ 3个任务(4     3     3)

2 HDFS参数调优

hadoop-env.sh" style="margin-left:0px;text-align:justify;">(1)修改:hadoop-env.sh

export HDFS_NAMENODE_OPTS="-Dhadoop.security.logger=INFO,RFAS -Xmx1024m"


export HDFS_DATANODE_OPTS="-Dhadoop.security.logger=ERROR,RFAS -Xmx1024m"

hdfs-site.xml" style="margin-left:0px;text-align:justify;">(2)修改hdfs-site.xml

<!-- NameNode有一个工作线程池,默认值是10 -->

<property>

    <name>dfs.namenode.handler.count</name>

    <value>21</value>

</property>

(3)修改core-site.xml

<!-- 配置垃圾回收时间为60分钟 -->

<property>

    <name>fs.trash.interval</name>

    <value>60</value>

</property>

(4)分发配置

xsync hadoop-env.sh hdfs-site.xml core-site.xml

3 MapReduce参数调优

(1)修改mapred-site.xml

<!-- 环形缓冲区大小,默认100m -->

<property>

  <name>mapreduce.task.io.sort.mb</name>

  <value>100</value>

</property>



<!-- 环形缓冲区溢写阈值,默认0.8 -->

<property>

  <name>mapreduce.map.sort.spill.percent</name>

  <value>0.80</value>

</property>



<!-- merge合并次数,默认10个 -->

<property>

  <name>mapreduce.task.io.sort.factor</name>

  <value>10</value>

</property>



<!-- maptask内存,默认1g; maptask堆内存大小默认和该值大小一致mapreduce.map.java.opts -->

<property>

  <name>mapreduce.map.memory.mb</name>

  <value>-1</value>

  <description>The amount of memory to request from the scheduler for each    map task. If this is not specified or is non-positive, it is inferred from mapreduce.map.java.opts and mapreduce.job.heap.memory-mb.ratio. If java-opts are also not specified, we set it to 1024.

  </description>

</property>



<!-- matask的CPU核数,默认1个 -->

<property>

  <name>mapreduce.map.cpu.vcores</name>

  <value>1</value>

</property>



<!-- matask异常重试次数,默认4次 -->

<property>

  <name>mapreduce.map.maxattempts</name>

  <value>4</value>

</property>



<!-- 每个Reduce去Map中拉取数据的并行数。默认值是5 -->

<property>

  <name>mapreduce.reduce.shuffle.parallelcopies</name>

  <value>5</value>

</property>



<!-- Buffer大小占Reduce可用内存的比例,默认值0.7 -->

<property>

  <name>mapreduce.reduce.shuffle.input.buffer.percent</name>

  <value>0.70</value>

</property>



<!-- Buffer中的数据达到多少比例开始写入磁盘,默认值0.66。 -->

<property>

  <name>mapreduce.reduce.shuffle.merge.percent</name>

  <value>0.66</value>

</property>



<!-- reducetask内存,默认1g;reducetask堆内存大小默认和该值大小一致mapreduce.reduce.java.opts -->

<property>

  <name>mapreduce.reduce.memory.mb</name>

  <value>-1</value>

  <description>The amount of memory to request from the scheduler for each    reduce task. If this is not specified or is non-positive, it is inferred

    from mapreduce.reduce.java.opts and mapreduce.job.heap.memory-mb.ratio.

    If java-opts are also not specified, we set it to 1024.

  </description>

</property>



<!-- reducetask的CPU核数,默认1个 -->

<property>

  <name>mapreduce.reduce.cpu.vcores</name>

  <value>2</value>

</property>



<!-- reducetask失败重试次数,默认4次 -->

<property>

  <name>mapreduce.reduce.maxattempts</name>

  <value>4</value>

</property>



<!-- 当MapTask完成的比例达到该值后才会为ReduceTask申请资源。默认是0.05 -->

<property>

  <name>mapreduce.job.reduce.slowstart.completedmaps</name>

  <value>0.05</value>

</property>



<!-- 如果程序在规定的默认10分钟内没有读到数据,将强制超时退出 -->

<property>

  <name>mapreduce.task.timeout</name>

  <value>600000</value>

</property>

(2)分发配置

xsync mapred-site.xml

4 Yarn参数调优

(1)修改yarn-site.xml配置参数如下

<!-- 选择调度器,默认容量 -->

<property>

    <description>The class to use as the resource scheduler.</description>

    <name>yarn.resourcemanager.scheduler.class</name>

<value>org.apache.hadoop.yarn.server.resourcemanager.scheduler.capacity.CapacityScheduler</value>

</property>



<!-- ResourceManager处理调度器请求的线程数量,默认50;如果提交的任务数大于50,可以增加该值,但是不能超过3台 * 4线程 = 12线程(去除其他应用程序实际不能超过8) -->

<property>

    <description>Number of threads to handle scheduler interface.</description>

    <name>yarn.resourcemanager.scheduler.client.thread-count</name>

    <value>8</value>

</property>



<!-- 是否让yarn自动检测硬件进行配置,默认是false,如果该节点有很多其他应用程序,建议手动配置。如果该节点没有其他应用程序,可以采用自动 -->

<property>

    <description>Enable auto-detection of node capabilities such as

    memory and CPU.

    </description>

    <name>yarn.nodemanager.resource.detect-hardware-capabilities</name>

    <value>false</value>

</property>



<!-- 是否将虚拟核数当作CPU核数,默认是false,采用物理CPU核数 -->

<property>

    <description>Flag to determine if logical processors(such as

    hyperthreads) should be counted as cores. Only applicable on Linux

    when yarn.nodemanager.resource.cpu-vcores is set to -1 and

    yarn.nodemanager.resource.detect-hardware-capabilities is true.

    </description>

    <name>yarn.nodemanager.resource.count-logical-processors-as-cores</name>

    <value>false</value>

</property>



<!-- 虚拟核数和物理核数乘数,默认是1.0 -->

<property>

    <description>Multiplier to determine how to convert phyiscal cores to

    vcores. This value is used if yarn.nodemanager.resource.cpu-vcores

    is set to -1(which implies auto-calculate vcores) and

    yarn.nodemanager.resource.detect-hardware-capabilities is set to true. The number of vcores will be calculated as number of CPUs * multiplier.

    </description>

    <name>yarn.nodemanager.resource.pcores-vcores-multiplier</name>

    <value>1.0</value>

</property>



<!-- NodeManager使用内存数,默认8G,修改为4G内存 -->

<property>

    <description>Amount of physical memory, in MB, that can be allocated

    for containers. If set to -1 and

    yarn.nodemanager.resource.detect-hardware-capabilities is true, it is

    automatically calculated(in case of Windows and Linux).

    In other cases, the default is 8192MB.

    </description>

    <name>yarn.nodemanager.resource.memory-mb</name>

    <value>4096</value>

</property>



<!-- nodemanager的CPU核数,不按照硬件环境自动设定时默认是8个,修改为4个 -->

<property>

    <description>Number of vcores that can be allocated

    for containers. This is used by the RM scheduler when allocating

    resources for containers. This is not used to limit the number of

    CPUs used by YARN containers. If it is set to -1 and

    yarn.nodemanager.resource.detect-hardware-capabilities is true, it is

   automatically determined from the hardware in case of Windows and Linux.

    In other cases, number of vcores is 8 by default.</description>

    <name>yarn.nodemanager.resource.cpu-vcores</name>

    <value>4</value>

</property>



<!-- 容器最小内存,默认1G -->

<property>

    <description>The minimum allocation for every container request at the RM  in MBs. Memory requests lower than this will be set to the value of this    property. Additionally, a node manager that is configured to have less memory than this value will be shut down by the resource manager.

    </description>

    <name>yarn.scheduler.minimum-allocation-mb</name>

    <value>1024</value>

</property>



<!-- 容器最大内存,默认8G,修改为2G -->

<property>

    <description>The maximum allocation for every container request at the RM  in MBs. Memory requests higher than this will throw an    InvalidResourceRequestException.

    </description>

    <name>yarn.scheduler.maximum-allocation-mb</name>

    <value>2048</value>

</property>



<!-- 容器最小CPU核数,默认1个 -->

<property>

    <description>The minimum allocation for every container request at the RM  in terms of virtual CPU cores. Requests lower than this will be set to the value of this property. Additionally, a node manager that is configured to  have fewer virtual cores than this value will be shut down by the resource    manager.

    </description>

    <name>yarn.scheduler.minimum-allocation-vcores</name>

    <value>1</value>

</property>



<!-- 容器最大CPU核数,默认4个,修改为2个 -->

<property>

    <description>The maximum allocation for every container request at the RM  in terms of virtual CPU cores. Requests higher than this will throw an

    InvalidResourceRequestException.</description>

    <name>yarn.scheduler.maximum-allocation-vcores</name>

    <value>2</value>

</property>



<!-- 虚拟内存检查,默认打开,修改为关闭 -->

<property>

    <description>Whether virtual memory limits will be enforced for

    containers.</description>

    <name>yarn.nodemanager.vmem-check-enabled</name>

    <value>false</value>

</property>



<!-- 虚拟内存和物理内存设置比例,默认2.1 -->

<property>

    <description>Ratio between virtual memory to physical memory when    setting memory limits for containers. Container allocations are    expressed in terms of physical memory, and virtual memory usage   is allowed to exceed this allocation by this ratio.

    </description>

    <name>yarn.nodemanager.vmem-pmem-ratio</name>

    <value>2.1</value>

</property>

(2)分发配置

xsync yarn-site.xml

5 执行程序

(1)重启集群

sbin/stop-yarn.sh


sbin/start-yarn.sh

(2)执行WordCount程序

hadoop jar share/hadoop/mapreduce/hadoop-mapreduce-examples-3.1.3.jar wordcount /input /output

(3)观察Yarn任务执行页面

http://hadoop103:8088/cluster/apps


http://www.niftyadmin.cn/n/156780.html

相关文章

2023年中国高校计算机大赛-团队程序设计天梯赛(GPLT)上海理工大学校内选拔赛(同步赛)

完型填空 思路&#xff1a;背包 用dp[i][j[k][h]表示在选了i道题的情况下&#xff0c;其中选了j道a,k道b&#xff0c;h道c,i-(jkh)道d时的最大期望注意是每层循环&#xff0c;每道题选的数目不超过n/4&#xff0c;在选第i道题目时&#xff0c;之前选的所有题目和应该小于i #i…

Framework事件机制—Android事件处理的三种方法

1.1.背景 Android的事件处理的三种方法&#xff1a; 1、基于监听的事件处理机制 setOnClickListener&#xff0c;setOnLongClickListener、setOnTouchListener 注意&#xff1a;如果onTouchEvent方法return true&#xff0c;则单击事件和长摁事件不再执行&#xff1b;若onL…

Cadence Allegro 导出Net Single Pin and No Pin报告详解

⏪《上一篇》   🏡《上级目录》   ⏩《下一篇》 目录 1,概述2,Net Single Pin and No Pin作用3,Net Single Pin and No Pin示例4,Net Single Pin and No Pin导出方法4.1,方法14.2,方法2B站关注“硬小二”浏览更多演示视频

系统集成项目管理工程师:第6章项目整体管理学习笔记

第6章项目整体管理 一、目录 6.1 项目整体管理概述 6.1.1 项目整体管理的含义、作用和过程 6.1.2 项目经理是整合者 6.1.3 整体管理的地位 6.2 项目整体管理实现过程 6.2.1 制订项目章程概述 6.2.2 制订项目章程

jquery实现自定义消息提示组件

目录结构 message icon error.svgwarning.svgsuccess.svgnormal.svg index.cssindex.jsindex.html 效果图 配置项 close:false,actionFns:null,message:‘’,boxClass:‘’,iconClass:‘’,endClass:‘’,textClass:‘’,endHtml:‘’,placement:‘top’time:4000parent:‘…

c++高性能:多进程 cuda编程

GPU(Device)用于异构计算&#xff0c;CPU(Host)控制GPU。极简入门。API(CUDA Driver APICUDA Runtime APICUDA Libraries) hello world // main.cu #include <iostream> #include <stdio.h>void cpu_hello(){printf("cpu\n"); } __global__ void cuda_…

【springboot】拦截器

6、拦截器 1、HandlerInterceptor 接口 /*** 登录检查* 1、配置好拦截器要拦截哪些请求* 2、把这些配置放在容器中*/ Slf4j public class LoginInterceptor implements HandlerInterceptor {/*** 目标方法执行之前* param request* param response* param handler* return* t…

ChatGPT技术原理解析:从RL之PPO算法、RLHF到GPT4、instructGPT

写在最前面&#xff0c;23年2.27日起&#xff0c;我个人和十来位博士朋友精读100篇ChatGPT相关技术的论文(每天一篇&#xff0c;100天读完100篇&#xff0c;这100篇的论文清单见此文)&#xff0c;过程中几乎每天都会不断优化本文&#xff0c;优化记录见本文文末的“后记”中.. …