Hadoop综合调优-企业开发场景案例

Hadoop综合调优-企业开发场景案例

hadoop版本:3.1.3

1 需求

  1. 场景
    从 1G 数据中,统计每个单词出现次数。服务器 3 台,每台配置 4G 内存,4 核 CPU,4 线程。
  2. 求分析
    1G / 128m = 8 个 MapTask;1 个 ReduceTask;1 个 mrAppMaster,平均每个节点运行 10 个 / 3 台 ≈ 3 个任务(4 3 3)
  3. 服务器部署规划
hadoop100hadoop200hadoop300
hdfsNameNode,DataNodeDataNodeSecondaryNameNode ,DataNode
yarnNodeManagerResourceManager ,NodeManagerNodeManager
内存4G4G4G
cpu4核4核4核
线程数444

2 HDFS参数调优

hdf参数调优详细说明:https://blog.csdn.net/qq_27242695/article/details/120787453

2.1 修改hadoop-env.sh

# 设置nameNode内存
export HDFS_NAMENODE_OPTS="-Dhadoop.security.logger=INFO,RFAS -Xmx1024m"
# 设置dataNode内存
export HDFS_DATANODE_OPTS="-Dhadoop.security.logger=ERROR,RFAS-Xmx1024m"

2.2 修改hdfs-site.xml

<!-- NameNode 有一个工作线程池,默认值是 10 -->
<property>
 <name>dfs.namenode.handler.count</name>
 <value>21</value>
</property>

2.3 修改core-site.xml

<!-- 配置垃圾回收时间为 60 分钟 -->
<property>
 <name>fs.trash.interval</name>
  <value>60</value>
</property>

2.4 分发到每台服务器

3 MapReduce 参数调优

mapReduce调优详细说明:https://blog.csdn.net/qq_27242695/article/details/120893997

3.1 修改 yarn-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>

3.2 分发到每台服务器

Yarn调优详细说明:https://blog.csdn.net/qq_27242695/article/details/120653791

4 Yarn 参数调优

4.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 asmemory 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 ashyperthreads) should be counted as cores. Only applicable on Linux
  when yarn.nodemanager.resource.cpu-vcores is set to -1 andyarn.nodemanager.resource.detect-hardware-capabilities is true.
  </description>
  <name>yarn.nodemanager.resource.count-logical-processors-ascores</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>

4.2 分发到每台服务器

5 重启集群

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值