5.Hadoop之生产调优

1.HDFS——核心参数

1.1 NameNode 内存生产配置

1)NameNode 内存计算
每个文件块大概占用 150byte,一台服务器 128G 内存为例,能存储多少文件块呢?
128 * 1024 * 1024 * 1024 / 150Byte ≈ 9.1 亿
2)Hadoop2.x 系列,配置 NameNode 内存
NameNode 内存默认 2000m,如果服务器内存 4G,NameNode 内存可以配置 3g。在hadoop-env.sh 文件中配置如下。

HADOOP_NAMENODE_OPTS=-Xmx3072m

3)Hadoop3.x 系列,配置 NameNode 内存
(1)hadoop-env.sh 中描述 Hadoop 的内存是动态分配的

# The maximum amount of heap to use (Java -Xmx). If no unit
# is provided, it will be converted to MB. Daemons will
# prefer any Xmx setting in their respective _OPT variable.
# There is no default; the JVM will autoscale based upon machine
# memory size.
# export HADOOP_HEAPSIZE_MAX=
# The minimum amount of heap to use (Java -Xms). If no unit
# is provided, it will be converted to MB. Daemons will
# prefer any Xms setting in their respective _OPT variable.
# There is no default; the JVM will autoscale based upon machine
# memory size.
# export HADOOP_HEAPSIZE_MIN=
HADOOP_NAMENODE_OPTS=-Xmx102400m

(2)查看 NameNode 占用内存

$ jpsall
=============== TestNode1 ===============
577 NameNode
898 NodeManager
1028 Jps
996 JobHistoryServer
680 DataNode

$ jmap -heap 577
MaxHeapSize              = 524288000 (500.0MB)

(3)查看 DataNode 占用内存

$ jmap -heap 680
MaxHeapSize              = 524288000 (500.0MB)

查看发现 TestNode1 上的 NameNode 和 DataNode 占用内存都是自动分配的,且相等。不是很合理。
经验参考:https://docs.cloudera.com/documentation/enterprise/6/release-notes/topics/rg_hardware_requirements.html#concept_fzz_dq4_gbb
NameNode:namenode最小值1G,每增加1000000个block,增加1G内存
DataNode:datanode最小值4G,block数,或者副本数升高,都应该调大datanode的值;一个datanode上的副本数低于4000000调为4G,超过4000000,每增加1000000,增加1G

具体修改:hadoop-env.sh

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

重启集群后生效

1.2 NameNode 心跳并发配置

1)hdfs-site.xml
NameNode 有一个工作线程池,用来处理不同 DataNode 的并发心跳以及客户端并发的元数据操作。
对于大集群或者有大量客户端的集群来说,通常需要增大该参数。默认值是 10。


    dfs.namenode.handler.count
    27

企业经验:

dfs.namenode.handler.count = 20 * log_{e}^{Cluster size}

比如集群规模(DataNode 台
数)为 4 台时,此参数设置为 27。可通过简单的 python 代码计算该值,代码如下。

$ python
Python 2.7.16 (default, Oct 10 2019, 22:02:15)
[GCC 8.3.0] on linux2
Type "help", "copyright", "credits" or "license" for more information.
>>> import math
>>> print int(20*math.log(4))
27
>>> exit()

1.3 开启回收站配置

开启回收站功能,可以将删除的文件在不超时的情况下,恢复原数据,起到防止误删除、备份等作用。
1)开启回收站功能参数说明
(1)默认值 fs.trash.interval = 0,0 表示禁用回收站;其他值表示设置文件的存活时间。
(2)默认值 fs.trash.checkpoint.interval = 0,检查回收站的间隔时间。如果该值为 0,则该值设置和 fs.trash.interval 的参数值相等。
(3)要求 fs.trash.checkpoint.interval <= fs.trash.interval。

2)启用回收站
修改 core-site.xml,配置垃圾回收时间为 1 分钟。

    
        fs.trash.interval
        1
    

记得分发配置,重启服务器后生效
3)查看回收站
回收站目录在 HDFS 集群中的路径:/user/atguigu/.Trash/….
4)注意:通过网页上直接删除的文件也不会走回收站。
6)通过程序删除的文件不会经过回收站,需要调用 moveToTrash()才进入回收站

Trash trash = New Trash(conf);
trash.moveToTrash(path);

7)只有在命令行利用 hadoop fs -rm 命令删除的文件才会走回收站。

$ hadoop fs -rm -r /output
2022-04-04 02:32:34,138 INFO fs.TrashPolicyDefault: Moved: 'hdfs://TestNode1:9000/output' to trash at: hdfs://TestNode1:9000/user/mgmt/.Trash/Current/output

8)恢复回收站数据

$ hadoop fs -mv /user/mgmt/.Trash/Current/output /output

2.HDFS—集群压测

在企业中非常关心每天从 Java 后台拉取过来的数据,需要多久能上传到集群?消费者关心多久能从 HDFS 上拉取需要的数据?
实验可以将4 虚拟机网络都设置为 100mbps。(由于virtualbox好像不支持,因此没修改)
100Mbps 单位是 bit;10M/s 单位是 byte ; 1byte=8bit,100Mbps/8=12.5M/s。

为了搞清楚 HDFS 的读写性能,生产环境上非常需要对集群进行压测。
HDFS 的读写性能主要受网络和磁盘影响比较大。
测试网速:来到 TestNode1 的/opt/module 目录,创建一个

$ python -m SimpleHTTPServer

2.1 测试 HDFS 写性能

0)写测试底层原理
Throughput=所有数据量累加/总时间
Average IO rate=(map1的平均速度+…+mp11的平均速度) / 10
1)测试内容:向 HDFS 集群写 10 个 128M 的文件

$ hadoop jar /opt/module/hadoop-3.1.3/share/hadoop/mapreduce/hadoop-mapreduce-client-jobclient-3.1.3-tests.jar TestDFSIO -write -nrFiles 10 -fileSize 128MB

2022-04-04 03:09:04,540 INFO fs.TestDFSIO: ----- TestDFSIO ----- : write
2022-04-04 03:09:04,542 INFO fs.TestDFSIO:             Date & time: Mon Apr 04 03:09:04 EDT 2022
2022-04-04 03:09:04,542 INFO fs.TestDFSIO:         Number of files: 10
2022-04-04 03:09:04,543 INFO fs.TestDFSIO:  Total MBytes processed: 1280
2022-04-04 03:09:04,543 INFO fs.TestDFSIO:       Throughput mb/sec: 8.47
2022-04-04 03:09:04,543 INFO fs.TestDFSIO:  Average IO rate mb/sec: 25.24
2022-04-04 03:09:04,543 INFO fs.TestDFSIO:   IO rate std deviation: 37.58
2022-04-04 03:09:04,543 INFO fs.TestDFSIO:      Test exec time sec: 88.41
2022-04-04 03:09:04,543 INFO fs.TestDFSIO:

注意:nrFiles n 为生成 mapTask 的数量,生产环境一般可通过 TestNode2:8088 查看 CPU核数,设置为(CPU 核数 - 1)

  • Number of files:生成 mapTask 数量,一般是集群中(CPU 核数-1),我们测试虚拟机就按照实际的物理内存-1 分配即可
  • Total MBytes processed:单个 map 处理的文件大小
  • Throughput mb/sec:单个 mapTak 的吞吐量
    计算方式:处理的总文件大小/每一个 mapTask 写数据的时间累加
    集群整体吞吐量:生成 mapTask 数量*单个 mapTak 的吞吐量
  • Average IO rate mb/sec::平均 mapTak 的吞吐量
    计算方式:每个 mapTask 处理文件大小/每一个 mapTask 写数据的时间全部相加除以 task 数量
  • IO rate std deviation:方差、反映各个 mapTask 处理的差值,越小越均衡

2)注意:如果测试过程中,出现异常
(1)可以在 yarn-site.xml 中设置虚拟内存检测为 false

    
    
        yarn.nodemanager.vmem-check-enabled
        false
    

(2)分发配置并重启 Yarn 集群
3)测试结果分析
(1)由于副本 1 就在本地,所以该副本不参与测试
一共参与测试的文件:10 个文件 * 3 个副本 = 30 个
压测后的速度:8.47
实测速度:8.47M/s * 30 个文件 ≈ 254.1M/s

如果实测速度远远小于网络,并且实测速度不能满足工作需求,可以考虑采用固态硬盘或者增加磁盘个数。
(2)如果客户端不在集群节点,那就三个副本都参与计算

2.2 测试 HDFS 读性能

1)测试内容:读取 HDFS 集群 10 个 128M 的文件

$ hadoop jar /opt/module/hadoop-3.1.3/share/hadoop/mapreduce/hadoop-mapreduce-client-jobclient-3.1.3-tests.jar TestDFSIO -read -nrFiles 10 -fileSize 128MB

2022-04-04 03:13:04,814 INFO fs.TestDFSIO: ----- TestDFSIO ----- : read
2022-04-04 03:13:04,815 INFO fs.TestDFSIO:             Date & time: Mon Apr 04 03:13:04 EDT 2022
2022-04-04 03:13:04,815 INFO fs.TestDFSIO:         Number of files: 10
2022-04-04 03:13:04,815 INFO fs.TestDFSIO:  Total MBytes processed: 1280
2022-04-04 03:13:04,815 INFO fs.TestDFSIO:       Throughput mb/sec: 38.58
2022-04-04 03:13:04,815 INFO fs.TestDFSIO:  Average IO rate mb/sec: 84.31
2022-04-04 03:13:04,815 INFO fs.TestDFSIO:   IO rate std deviation: 104.68
2022-04-04 03:13:04,815 INFO fs.TestDFSIO:      Test exec time sec: 41.48
2022-04-04 03:13:04,815 INFO fs.TestDFSIO:

2)删除测试生成数据

$ hadoop jar /opt/module/hadoop-3.1.3/share/hadoop/mapreduce/hadoop-mapreduce-client-jobclient-3.1.3-tests.jar TestDFSIO -clean

3)测试结果分析:为什么读取文件速度大于网络带宽?由于目前只有四台服务器,且有四个副本,数据读取就近原则,相当于都是读取的本地磁盘数据,没有走网络。

3.HDFS—多目录

3.1 NameNode 多目录配置(在安装集群时已经做了,因此没有操作以下内容)

1)NameNode 的本地目录可以配置成多个,且每个目录存放内容相同,增加了可靠性
2)具体配置如下
(1)在 hdfs-site.xml 文件中添加如下内容

<property>
 <name>dfs.namenode.name.dir</name>
    <value>file://${hadoop.tmp.dir}/dfs/name1,file://${hadoop.tmp.dir}/dfs/name2</value>
</property>

注意:因为每台服务器节点的磁盘情况不同,所以这个配置配完之后,可以选择不分发
(2)停止集群,删除所有台节点的 data 和 logs 中所有数据。
(3)格式化集群并启动。

$ hdfs namenode -format
$ myhadoop.sh start

3.2 DataNode 多目录配置(已经配置不再操作)

1)DataNode 可以配置成多个目录,每个目录存储的数据不一样(数据不是副本)
2)具体配置如下
在 hdfs-site.xml 文件中添加如下内容


    dfs.datanode.data.dir
    file://${hadoop.tmp.dir}/dfs/data1,file://${hadoop.tmp.dir}/dfs/data2

4)向集群上传一个文件,再次观察两个文件夹里面的内容发现不一致(一个有数一个没有)

3.3 集群数据均衡之磁盘间数据均衡(虚拟机只有一块硬盘,无法操作)

生产环境,由于硬盘空间不足,往往需要增加一块硬盘。刚加载的硬盘没有数据时,可以执行磁盘数据均衡命令。(Hadoop3.x 新特性)
(1)生成均衡计划(我们只有一块磁盘,不会生成计划)

$ hdfs diskbalancer -plan TestNode1

(2)执行均衡计划

$ hdfs diskbalancer -execute TestNode1.plan.json

(3)查看当前均衡任务的执行情况

$ hdfs diskbalancer -query TestNode1

(4)取消均衡任务

$ hdfs diskbalancer -cancel TestNode1.plan.json

4.HDFS—集群扩容及缩容

4.1 添加白名单

白名单:表示在白名单的主机 IP 地址可以,用来存储数据。
企业中:配置白名单,可以尽量防止黑客恶意访问攻击。
配置白名单步骤如下:
1)在 NameNode 节点的/opt/module/hadoop-3.1.3/etc/hadoop 目录下分别创建 whitelist 和blacklist 文件
(1)创建白名单

$ vim /opt/module/hadoop-3.1.3/etc/hadoop/whitelist

在 whitelist 中添加如下主机名称,假如集群正常工作的节点为 1 2 3

TestNode1
TestNode2
TestNode3

(2)创建黑名单

$ touch /opt/module/hadoop-3.1.3/etc/hadoop/blacklist

保持空的就可以
2)在 hdfs-site.xml 配置文件中增加 dfs.hosts 配置参数

    
    
        dfs.hosts
        /opt/module/hadoop-3.1.3/etc/hadoop/whitelist
    
    
    
        dfs.hosts.exclude
        /opt/module/hadoop-3.1.3/etc/hadoop/blacklist
    

3)分发配置文件 whitelist,blacklist,hdfs-site.xml

$ xsync /opt/module/hadoop-3.1.3/etc/hadoop/

4)第一次添加白名单必须重启集群,不是第一次,只需要刷新 NameNode 节点即可

$ myhadoop.sh stop
$ myhadoop.sh start

5)在 web 浏览器上查看 DN, http://testnode1:50070/dfshealth.html#tab-datanode
6)二次修改白名单,增加 TestNode4

$ vim /opt/module/hadoop-3.1.3/etc/hadoop/whitelist
添加TestNode4
$ xsync /opt/module/hadoop-3.1.3/etc/hadoop/whitelist

7)刷新 NameNode

$ hdfs dfsadmin -refreshNodes

8)在 web 浏览器上查看 DN, http://testnode1:50070/dfshealth.html#tab-datanode

4.2 服役新服务器

1)需求
随着公司业务的增长,数据量越来越大,原有的数据节点的容量已经不能满足存储数据的需求,需要在原有集群基础上动态添加新的数据节点。
2)环境准备
(1)克隆一台 TestNode5 主机
(2)修改 IP 地址和主机名称,安装hadoop,java等正常配置好服务器
(4)删除 TestNode5 上 Hadoop 的历史数据,data 和 log 数据
3)服役新节点具体步骤
(1)直接启动 DataNode,即可关联到集群

$ hdfs --daemon start datanode
$ yarn --daemon start nodemanager

4)在白名单中增加新服役的服务器
(1)在白名单 whitelist 中增加 hadoop104、hadoop105,并重启集群
在白名单中添加TestNode5,然后分发
(3)刷新 NameNode

$ hdfs dfsadmin -refreshNodes

思考:如果数据不均衡(TestNode5数据少,其他节点数据多),怎么处理?

4.3 服务器间数据均衡

1)企业经验:
在企业开发中,如果经常在 TestNode1 和 TestNode2 上提交任务,且副本数为 2,由数据本地性原则,就会导致 TestNode1 和 TestNode2 数据过多,TestNode3 存储的数据量小。
另一种情况,就是新服役的服务器数据量比较少,需要执行集群均衡命令。
2)开启数据均衡命令:

$ start-balancer.sh -threshold 10

对于参数 10,代表的是集群中各个节点的磁盘空间利用率相差不超过 10%,可根据实际情况进行调整。
3)停止数据均衡命令:

$ stop-balancer.sh -threshold 10

注意:由于 HDFS 需要启动单独的 Rebalance Server 来执行 Rebalance 操作,所以尽量不要在 NameNode 上执行 start-balancer.sh,而是找一台比较空闲的机器。

4.4 黑名单退役服务器

黑名单:表示在黑名单的主机 IP 地址不可以,用来存储数据。
企业中:配置黑名单,用来退役服务器。
黑名单配置步骤如下:
1)编辑/opt/module/hadoop-3.1.3/etc/hadoop 目录下的 blacklist 文件

$ vim blacklist
添加退役节点名
TestNode5

注意:如果白名单中没有配置,需要在 hdfs-site.xml 配置文件中增加 dfs.hosts 配置参数

    
    
        dfs.hosts.exclude
        /opt/module/hadoop-3.1.3/etc/hadoop/blacklist
    

2)分发配置文件 blacklist,hdfs-site.xml
3)第一次添加黑名单必须重启集群,不是第一次,只需要刷新 NameNode 节点即可

$ hdfs dfsadmin -refreshNodes

4)检查 Web 浏览器,退役节点的状态为 decommission in progress(退役中),说明数据
节点正在复制块到其他节点
5)等待退役节点状态为 decommissioned(所有块已经复制完成),停止该节点及节点资源管理器。注意:如果副本数是 3,服役的节点小于等于 3,是不能退役成功的,需要修改副本数后才能退役

$ hdfs --daemon stop datanode
$ yarn --daemon stop nodemanager

6)如果数据不均衡,可以用命令实现集群的再平衡

$ start-balancer.sh -threshold 10

5.HDFS—存储优化

注:演示纠删码和异构存储需要一共 5 台虚拟机。尽量拿另外一套集群。提前准备 5 台服务器的集群。

5.1 纠删码

5.1.1 纠删码原理

HDFS 默认情况下,一个文件有 3 个副本,这样提高了数据的可靠性,但也带来了 2 倍的冗余开销。Hadoop3.x 引入了纠删码,采用计算的方式,可以节省约 50%左右的存储空间。
1)纠删码操作相关的命令

$ hdfs ec
Usage: bin/hdfs ec [COMMAND]
          [-listPolicies]
          [-addPolicies -policyFile <file>]
          [-getPolicy -path <path>]
          [-removePolicy -policy <policy>]
          [-setPolicy -path <path> [-policy <policy>] [-replicate]]
          [-unsetPolicy -path <path>]
          [-listCodecs]
          [-enablePolicy -policy <policy>]
          [-disablePolicy -policy <policy>]
          [-help <command-name>]

2)查看当前支持的纠删码策略

$ hdfs ec -listPolicies
Erasure Coding Policies:
ErasureCodingPolicy=[Name=RS-10-4-1024k, Schema=[ECSchema=[Codec=rs, numDataUnits=10, numParityUnits=4]], CellSize=1048576, Id=5], State=DISABLED
ErasureCodingPolicy=[Name=RS-3-2-1024k, Schema=[ECSchema=[Codec=rs, numDataUnits=3, numParityUnits=2]], CellSize=1048576, Id=2], State=DISABLED
ErasureCodingPolicy=[Name=RS-6-3-1024k, Schema=[ECSchema=[Codec=rs, numDataUnits=6, numParityUnits=3]], CellSize=1048576, Id=1], State=ENABLED
ErasureCodingPolicy=[Name=RS-LEGACY-6-3-1024k, Schema=[ECSchema=[Codec=rs-legacy, numDataUnits=6, numParityUnits=3]], CellSize=1048576, Id=3], State=DISABLED
ErasureCodingPolicy=[Name=XOR-2-1-1024k, Schema=[ECSchema=[Codec=xor, numDataUnits=2, numParityUnits=1]], CellSize=1048576, Id=4], State=DISABLED

3)纠删码策略解释:
RS-3-2-1024k:使用 RS 编码,每 3 个数据单元,生成 2 个校验单元,共 5 个单元,也就是说:这 5 个单元中,只要有任意的 3 个单元存在(不管是数据单元还是校验单元,只要总数=3),就可以得到原始数据。每个单元的大小是 1024k=1024*1024=1048576。

RS-10-4-1024k:使用 RS 编码,每 10 个数据单元(cell),生成 4 个校验单元,共 14个单元,也就是说:这 14 个单元中,只要有任意的 10 个单元存在(不管是数据单元还是校验单元,只要总数=10),就可以得到原始数据。每个单元的大小是 1024k=1024*1024=1048576。

RS-6-3-1024k:使用 RS 编码,每 6 个数据单元,生成 3 个校验单元,共 9 个单元,也就是说:这 9 个单元中,只要有任意的 6 个单元存在(不管是数据单元还是校验单元,只要总数=6),就可以得到原始数据。每个单元的大小是 1024k=1024*1024=1048576。

RS-LEGACY-6-3-1024k:策略和上面的 RS-6-3-1024k 一样,只是编码的算法用的是 rs-legacy。

XOR-2-1-1024k:使用 XOR 编码(速度比 RS 编码快),每 2 个数据单元,生成 1 个校验单元,共 3 个单元,也就是说:这 3 个单元中,只要有任意的 2 个单元存在(不管是数据单元还是校验单元,只要总数= 2),就可以得到原始数据。每个单元的大小是
1024k=1024*1024=1048576。

5.1.2 纠删码案例实操

纠删码策略是给具体一个路径设置。所有往此路径下存储的文件,都会执行此策略。默认只开启对 RS-6-3-1024k 策略的支持,如要使用别的策略需要提前启用。

1)需求:将/input 目录设置为 RS-3-2-1024k 策略
2)具体步骤
(1)开启对 RS-3-2-1024k 策略的支持

$ hdfs ec -enablePolicy -policy RS-3-2-1024k

(2)在 HDFS 创建目录,并设置 RS-3-2-1024k 策略

$ hdfs dfs -mkdir /input
$ hdfs ec -setPolicy -path /input -policy RS-3-2-1024k

(3)上传文件,并查看文件编码后的存储情况

$ hdfs dfs -put web.log /input

注:你所上传的文件需要大于 2M 才能看出效果。(低于 2M,只有一个数据单元和两个校验单元)
(4)查看存储路径的数据单元和校验单元,并作破坏实验

5.2 异构存储(冷热数据分离)

异构存储主要解决,不同的数据,存储在不同类型的硬盘中,达到最佳性能的问题。
1)关于存储类型
RAM_DISK:(内存镜像文件系统)
SSD:(SSD固态硬盘)
DISK:(普通磁盘,在HDFS中,如果没有主动声明数据目录存储类型默认都是DISK)
ARCHIVE:(没有特指哪种存储介质,主要的指的是计算能力比较弱而存储密度比较高的存储介质,用来解决数据量的容量扩增的问题,一般用于归档)

2)关于存储策略
说明:从Lazy_Persist到Cold,分别代表了设备的访问速度从快到慢

策略ID 策略名称 副本分布 说明
15 Lazy_Persist RAM_DISK:1,DISK:n-1 一个副本保存在内存RAM_DISK中,其余副本保存在磁盘中。
12 All_SSD SSD:n 所有副本都保存在SSD中。
10 One_SSD SSD:1,DISK:n-1 一个副本保存在SSD中,其余副本保存在磁盘中。
7 Hot(default) DISK:n Hot:所有副本保存在磁盘中,这也是默认的存储策略。
5 Warm DSIK:1,ARCHIVE:n-1 一个副本保存在磁盘上,其余副本保存在归档存储上。
2 Cold ARCHIVE:n 所有副本都保存在归档存储上。

5.2.1 异构存储 Shell

(1)查看当前有哪些存储策略可以用

$ hdfs storagepolicies -listPolicies

(2)为指定路径(数据存储目录)设置指定的存储策略

$ hdfs storagepolicies -setStoragePolicy -path xxx -policy xxx

(3)获取指定路径(数据存储目录或文件)的存储策略

$ hdfs storagepolicies -getStoragePolicy -path xxx

(4)取消存储策略;执行改命令之后该目录或者文件,以其上级的目录为准,如果是根目录,那么就是 HOT

$ hdfs storagepolicies -unsetStoragePolicy -path xxx

(5)查看文件块的分布

$ hdfs fsck xxx -files -blocks -locations

(6)查看集群节点

$ hadoop dfsadmin -report

5.2.2 测试环境准备

1)测试环境描述
服务器规模:5 台
集群配置:副本数为 2,创建好带有存储类型的目录(提前创建)
集群规划:

节点 存储类型分配
TestNode1 RAM_DISK,SSD
TestNode2 SSD,DISK
TestNode3 DISK,RAM_DISK
TestNode4 ARCHIVE
TestNode5 ARCHIVE

2)配置文件信息(配置hdfs-site.xml时要删除重复配置的内容后添加)
(1)为 TestNode1 节点的 hdfs-site.xml 添加如下信息

    
        dfs.replication
        2
    
    
        dfs.storage.policy.enabled
        true
    
    
        dfs.datanode.data.dir 
        [SSD]file:///opt/module/hadoop-3.1.3/hdfsdata/ssd,[RAM_DISK]file:///opt/module/hadoop-3.1.3/hdfsdata/ram_disk
    

(2)为 TestNode2 节点的 hdfs-site.xml 添加如下信息

    
        dfs.replication
        2
    
    
        dfs.storage.policy.enabled
        true
    
    
        dfs.datanode.data.dir
        [SSD]file:///opt/module/hadoop-3.1.3/hdfsdata/ssd,[DISK]file:///opt/module/hadoop-3.1.3/hdfsdata/disk
    

(3)为 TestNode3 节点的 hdfs-site.xml 添加如下信息

    
        dfs.replication
        2
    
    
        dfs.storage.policy.enabled
        true
    
    
        dfs.datanode.data.dir
        [RAM_DISK]file:///opt/module/hadoop-3.1.3/hdfsdata/ram_disk,[DISK]file:///opt/module/hadoop-3.1.3/hdfsdata/disk
    

(4)为 TestNode4 节点的 hdfs-site.xml 添加如下信息

    
        dfs.replication
        2
    
    
        dfs.storage.policy.enabled
        true
    
    
        dfs.datanode.data.dir
        [ARCHIVE]file:///opt/module/hadoop-3.1.3/hdfsdata/archive
    

(5)为 TestNode5 节点的 hdfs-site.xml 添加如下信息

    
        dfs.replication
        2
    
    
        dfs.storage.policy.enabled
        true
    
    
        dfs.datanode.data.dir
        [ARCHIVE]file:///opt/module/hadoop-3.1.3/hdfsdata/archive
    

3)数据准备(删除logs和data文件)
(1)启动集群

$ hdfs namenode -format
$ myhadoop.sh start

(2)并在 HDFS 上创建文件目录

$ hadoop fs -mkdir /hdfsdata

(3)并将文件资料上传

$ hadoop fs -put /opt/module/hadoop-3.1.3/NOTICE.txt /hdfsdata

5.2.3 HOT 存储策略案例

(1)最开始我们未设置存储策略的情况下,我们获取该目录的存储策略

$ hdfs storagepolicies -getStoragePolicy -path /hdfsdata

(2)我们查看上传的文件块分布

$ hdfs fsck /hdfsdata -files -blocks -locations

 [DatanodeInfoWithStorage[192.168.1.222:9866,DS-0665bf48-b2b6-4ab4-b4af-ddb2732c0ce1,DISK], DatanodeInfoWithStorage[192.168.1.223:9866,DS-b515fcf1-a963-4f77-b16c-8e8639df9cab,DISK]]

未设置存储策略,所有文件块都存储在 DISK 下。所以,默认存储策略为 HOT。

5.2.4 WARM 存储策略测试

(1)接下来我们为数据降温

$  hdfs storagepolicies -setStoragePolicy -path /hdfsdata -policy WARM

(2)再次查看文件块分布,我们可以看到文件块依然放在原处。

$ hdfs fsck /hdfsdata -files -blocks -locations

(3)我们需要让他 HDFS 按照存储策略自行移动文件块

$ hdfs mover /hdfsdata

(4)再次查看文件块分布,

$ hdfs fsck /hdfsdata -files -blocks -locations

[DatanodeInfoWithStorage[192.168.1.224:9866,DS-688e1d8a-cd5b-4eed-aefc-21b937b467bc,ARCHIVE], DatanodeInfoWithStorage[192.168.1.223:9866,DS-b515fcf1-a963-4f77-b16c-8e8639df9cab,DISK]]

文件块一半在 DISK,一半在 ARCHIVE,符合我们设置的 WARM 策略

5.2.5 COLD 策略测试

(1)我们继续将数据降温为 cold

$ hdfs storagepolicies -setStoragePolicy -path /hdfsdata -policy COLD

注意:当我们将目录设置为 COLD 并且我们未配置 ARCHIVE 存储目录的情况下,不可以向该目录直接上传文件,会报出异常。
(2)手动转移

$ hdfs mover /hdfsdata

(3)检查文件块的分布

$ hdfs fsck /hdfsdata -files -blocks -locations

[DatanodeInfoWithStorage[192.168.1.224:9866,DS-688e1d8a-cd5b-4eed-aefc-21b937b467bc,ARCHIVE], DatanodeInfoWithStorage[192.168.1.225:9866,DS-8d1595d4-396e-4964-ae8f-9fb547655385,ARCHIVE]]

5.2.6 ONE_SSD 策略测试

(1)接下来我们将存储策略从默认的 HOT 更改为 One_SSD

$ hdfs storagepolicies -setStoragePolicy -path /hdfsdata -policy One_SSD

(2)手动转移

$ hdfs mover /hdfsdata

(3)检查文件块的分布

$ hdfs fsck /hdfsdata -files -blocks -locations

[DatanodeInfoWithStorage[192.168.1.222:9866,DS-1ae1943c-9c8b-4cab-980a-d9f7bc095036,SSD], DatanodeInfoWithStorage[192.168.1.223:9866,DS-b515fcf1-a963-4f77-b16c-8e8639df9cab,DISK]]

5.2.7 ALL_SSD 策略测试

(1)接下来我们将存储策略从默认的 HOT 更改为 All_SSD

$ hdfs storagepolicies -setStoragePolicy -path /hdfsdata -policy All_SSD

(2)手动转移

$ hdfs mover /hdfsdata

(3)检查文件块的分布

$ hdfs fsck /hdfsdata -files -blocks -locations

[DatanodeInfoWithStorage[192.168.1.222:9866,DS-1ae1943c-9c8b-4cab-980a-d9f7bc095036,SSD], DatanodeInfoWithStorage[192.168.1.221:9866,DS-0c7cf8da-3999-4785-80b0-c7574e2afd48,SSD]]

所有的文件块都存储在 SSD,符合 All_SSD 存储策略.

5.2.8 LAZY_PERSIST 策略测试

(1)接下来我们将存储策略从默认的 HOT 更改为 lazy_persist

$ hdfs storagepolicies -setStoragePolicy -path /hdfsdata -policy lazy_persist

(2)手动转移

$ hdfs mover /hdfsdata

(3)检查文件块的分布

$ hdfs fsck /hdfsdata -files -blocks -locations

[DatanodeInfoWithStorage[192.168.1.223:9866,DS-b515fcf1-a963-4f77-b16c-8e8639df9cab,DISK], DatanodeInfoWithStorage[192.168.1.222:9866,DS-0665bf48-b2b6-4ab4-b4af-ddb2732c0ce1,DISK]]

这里我们发现所有的文件块都是存储在 DISK,按照理论一个副本存储在 RAM_DISK,其他副本存储在 DISK 中,这是因为,我们还需要配置“dfs.datanode.max.locked.memory”,“dfs.block.size”参数。

那么出现存储策略为 LAZY_PERSIST 时,文件块副本都存储在 DISK 上的原因有如下两点:
(1)当客户端所在的 DataNode 节点没有 RAM_DISK 时,则会写入客户端所在的DataNode 节点的 DISK 磁盘,其余副本会写入其他节点的 DISK 磁盘。
(2)当客户端所在的 DataNode 有 RAM_DISK,但“dfs.datanode.max.locked.memory”参数值未设置或者设置过小(小于“dfs.block.size”参数值)时,则会写入客户端所在的DataNode 节点的 DISK 磁盘,其余副本会写入其他节点的 DISK 磁盘。

但是由于虚拟机的“max locked memory”为 65536KB,所以,如果参数配置过大,还会报出错误:

ERROR org.apache.hadoop.hdfs.server.datanode.DataNode: Exception in secureMainjava.lang.RuntimeException: Cannot start datanode because the configured max locked memory size (dfs.datanode.max.locked.memory) of 209715200 bytes is more than the datanode's available RLIMIT_MEMLOCKulimit of 
65536 bytes.

我们可以通过该命令查询此参数的内存

$ ulimit -a
max locked memory       (kbytes, -l) 65536

6.HDFS—故障排

注意:采用三台服务器即可,恢复到 Yarn 开始的服务器快照。

6.1 NameNode 故障处理

1)需求:
NameNode 进程挂了并且存储的数据也丢失了,如何恢复 NameNode
2)故障模拟
(1)kill -9 NameNode 进程

$ jps
609 NameNode
930 NodeManager
1027 JobHistoryServer
712 DataNode
3100 Jps
$ kill -9 609

(2)删除 NameNode 存储的数据(/opt/module/hadoop-3.1.3/hdfs/name/)

$ rm -rf /opt/module/hadoop-3.1.3/hdfs/name/*

3)问题解决
(1)拷贝 SecondaryNameNode 中数据到原 NameNode 存储数据目录

$scp -r mgmt@TestNode3:/opt/module/hadoop-3.1.3/tmp/dfs/namesecondary/* ./name/

(2)重新启动 NameNode

$ hdfs --daemon start namenode

(3)向集群上传一个文件

6.2 集群安全模式&磁盘修复

1)安全模式:文件系统只接受读数据请求,而不接受删除、修改等变更请求
2)进入安全模式场景

  • NameNode 在加载镜像文件和编辑日志期间处于安全模式;
  • NameNode 再接收 DataNode 注册时,处于安全模式
    3)退出安全模式条件
    dfs.namenode.safemode.min.datanodes:最小可用 datanode 数量,默认 0
    dfs.namenode.safemode.threshold-pct:副本数达到最小要求的 block 占系统总 block 数的百分比,默认 0.999f。(只允许丢一个块)
    dfs.namenode.safemode.extension:稳定时间,默认值 30000 毫秒,即 30 秒
    4)基本语法
    集群处于安全模式,不能执行重要操作(写操作)。集群启动完成后,自动退出安全模式。
(1)hdfs dfsadmin -safemode get (功能描述:查看安全模式状态)
(2)hdfs dfsadmin -safemode enter (功能描述:进入安全模式状态)
(3)hdfs dfsadmin -safemode leave(功能描述:离开安全模式状态)
(4)hdfs dfsadmin -safemode wait (功能描述:等待安全模式状态)

5)案例 1:启动集群进入安全模式
(1)重新启动集群

$ myhadoop.sh stop
$ myhadoop.sh start

(2)集群启动后,立即来到集群上删除数据,提示集群处于安全模式

6)案例 2:磁盘修复
需求:数据块损坏,进入安全模式,如何处理
(1)分别进入TestNode1 、 TestNode2 、 TestNode3 、 TestNode4 的/opt/module/hadoop-3.1.3/hdfs/data/current/BP-1015489500-192.168.10.102-1611909480872/current/finalized/subdir0/subdir0 目录,统一删除某 2 个块信息
(2)重新启动集群
(3)观察 http://testnode1:50070/dfshealth.html#tab-overview
安全模式已经打开,块的数量没有达到要求。
(4)离开安全模式

$ hdfs dfsadmin -safemode get
$ hdfs dfsadmin -safemode leave

(5)观察 http://testnode1:50070/dfshealth.html#tab-overview
(6)将元数据删除后集群可正常使用

7)案例 3:
需求:模拟等待安全模式
(1)查看当前模式

$ hdfs dfsadmin -safemode get

(2)先进入安全模式

$ hdfs dfsadmin -safemode enter

(3)创建并执行下面的脚本
在/opt/module/hadoop-3.1.3 路径上,编辑一个脚本 safemode.sh

#!/bin/bash
hdfs dfsadmin -safemode wait
hdfs dfs -put /opt/module/hadoop-3.1.3/README.txt /
运行脚本
$ chmod 777 safemode.sh
$ ./safemode.sh

(4)再打开一个窗口,执行

$ hdfs dfsadmin -safemode leave

(5)再观察上一个窗口,发现脚本继续运行

6.3 慢磁盘监控

“慢磁盘”指的时写入数据非常慢的一类磁盘。其实慢性磁盘并不少见,当机器运行时间长了,上面跑的任务多了,磁盘的读写性能自然会退化,严重时就会出现写入数据延时的问题。

如何发现慢磁盘?
正常在 HDFS 上创建一个目录,只需要不到 1s 的时间。如果你发现创建目录超过 1 分钟及以上,而且这个现象并不是每次都有。只是偶尔慢了一下,就很有可能存在慢磁盘。可以采用如下方法找出是哪块磁盘慢:
1)通过心跳未联系时间。
一般出现慢磁盘现象,会影响到 DataNode 与 NameNode 之间的心跳。正常情况心跳时间间隔是 3s。超过 3s 说明有异常。
2)fio 命令,测试磁盘的读写性能

安装fio
$ sudo apt-get install -y fio
测试指令格式
$ sudo fio -filename=<文件路径> -direct=1 -iodepth 1 -thread -rw=模式 -ioengine=psync -bs=16k -size=2G -numjobs=10 -runtime=60 -group_reporting -name=test

read:顺序读
write:顺序写
randwrite:随机写
randrw:混合随机读写

6.4 小文件归档

1)HDFS 存储小文件弊端
每个文件均按块存储,每个块的元数据存储在 NameNode 的内存中,因此 HDFS 存储小文件会非常低效。因为大量的小文件会耗尽 NameNode 中的大部分内存。但注意,存储小文件所需要的磁盘容量和数据块的大小无关。例如,一个 1MB 的文件设置为 128MB 的块存储,实际使用的是 1MB 的磁盘空间,而不是 128MB。
2)解决存储小文件办法之一
HDFS 存档文件或 HAR 文件,是一个更高效的文件存档工具,它将文件存入 HDFS 块,在减少 NameNode 内存使用的同时,允许对文件进行透明的访问。具体说来,HDFS 存档文件对内还是一个一个独立文件,对 NameNode 而言却是一个整体,减少了 NameNode 的内存。
3)案例实操
(1)需要启动 YARN 进程

$ start-yarn.sh

(2)归档文件
把/input 目录里面的所有文件归档成一个叫 input.har 的归档文件,并把归档后文件存储到/output 路径下。

$ hadoop archive -archiveName input.har -p /input /output2

(3)查看归档

$ hadoop fs -ls /output2/input.har
$ hadoop fs -ls har:///output2/input.har

(4)解归档文件

$ hadoop fs -cp har:///output2/input.har/* /

7.HDFS—集群迁移

7.1 Apache 和 Apache 集群间数据拷贝

1)scp 实现两个远程主机之间的文件复制
scp -r hello.txt root@TestNode1:/user/mgmt/hello.txt // 推 push
scp -r root@TestNode1:/user/mgmt/hello.txt hello.txt // 拉 pull
scp -r root@TestNode1:/user/mgmt/hello.txt root@TestNode2:/user/mgmt //是通过本
地主机中转实现两个远程主机的文件复制;如果在两个远程主机之间 ssh 没有配置的情况下可以使用该方式。
2)采用 distcp 命令实现两个 Hadoop 集群之间的递归数据复制

$ hadoop distcp hdfs://TestNode1:8020/user/mgmt/hello.txt hdfs://TestNode2:8020/user/mgmt/hello.txt

7.2 Apache 和 CDH 集群间数据拷贝

8.MapReduce 生产经验

8.1 MapReduce 跑的慢的原因

MapReduce 程序效率的瓶颈在于两点:
1)计算机性能
CPU、内存、磁盘、网络
2)I/O 操作优化
(1)数据倾斜
(2)Map 运行时间太长,导致 Reduce 等待过久
(3)小文件过多

8.2 MapReduce 常用调优参数

Map阶段
1)自定义分区,减少数据倾斜;
定义类,继承Partitioner接口,重写getPartition方法
2)减少溢写的次数
mapreduce.task.io.sort.mbShuffle的环形缓冲区大小,默认100m,可以提高到200m
mapreduce.map.sort.spill.percent环形缓冲区溢出的阈值,默认80% ,可以提高的90%
3)增加每次Merge合并次数
mapreduce.task.io.sort.factor默认10,可以提高到20
4)在不影响业务结果的前提条件下可以提前采用Combiner
job.setCombinerClass(xxxReducer.class);
5)为了减少磁盘IO,可以采用Snappy或者LZO压缩
conf.setBoolean(“mapreduce.map.output.compress”, true);
conf.setClass(“mapreduce.map.output.compress.codec”, SnappyCodec.class,CompressionCodec.class);
6)mapreduce.map.memory.mb 默认MapTask内存上限1024MB。可以根据128m数据对应1G内存原则提高该内存。
7)mapreduce.map.java.opts:控制MapTask堆内存大小。(如果内存不够,报:java.lang.OutOfMemoryError)
8)mapreduce.map.cpu.vcores 默认MapTask的CPU核数1。计算密集型任务可以增加CPU核数
9)异常重试
mapreduce.map.maxattempts每个Map Task最大重试次数,一旦重试次数超过该值,则认为Map Task运行失败,默认值:4。根据机器性能适当提高。

Reduce阶段
1)mapreduce.reduce.shuffle.parallelcopies每个Reduce去Map中拉取数据的并行数,默认值是5。可以提高到10。
2)mapreduce.reduce.shuffle.input.buffer.percentBuffer大小占Reduce可用内存的比例,默认值0.7。可以提高到0.8
3)mapreduce.reduce.shuffle.merge.percent Buffer中的数据达到多少比例开始写入磁盘,默认值0.66。可以提高到0.75
4)mapreduce.reduce.memory.mb 默认ReduceTask内存上限1024MB,根据128m数据对应1G内存原则,适当提高内存到4-6G
5)mapreduce.reduce.java.opts:控制ReduceTask堆内存大小。(如果内存不够,报:java.lang.OutOfMemoryError)
6)mapreduce.reduce.cpu.vcores默认ReduceTask的CPU核数1个。可以提高到2-4个
7)mapreduce.reduce.maxattempts每个Reduce Task最大重试次数,一旦重试次数超过该值,则认为Map Task运行失败,默认值:4。
8)mapreduce.job.reduce.slowstart.completedmaps当MapTask完成的比例达到该值后才会为ReduceTask申请资源。默认是0.05。
9)mapreduce.task.timeout如果一个Task在一定时间内没有任何进入,即不会读取新的数据,也没有输出数据,则认为该Task处于Block状态,可能是卡住了,也许永远会卡住,为了防止因为用户程序永远Block住不退出,则强制设置了一个该超时时间(单位毫秒),默认是600000(10分钟)。如果你的程序对每条输入数据的处理时间过长,建议将该参数调大。
10)如果可以不用Reduce,尽可能不用

8.3 MapReduce 数据倾斜问题

1)数据倾斜现象
数据频率倾斜——某一个区域的数据量要远远大于其他区域。
数据大小倾斜——部分记录的大小远远大于平均值。
2)减少数据倾斜的方法
(1)首先检查是否空值过多造成的数据倾斜
生产环境,可以直接过滤掉空值;如果想保留空值,就自定义分区,将空值加随机数打散。最后再二次聚合。
(2)能在 map 阶段提前处理,最好先在 Map 阶段处理。如:Combiner、MapJoin
(3)设置多个 reduce 个数

9.Hadoop-Yarn 生产经验

9.1 常用的调优参数

1)调优参数列表
(1)Resourcemanager 相关

yarn.resourcemanager.scheduler.client.thread-count ResourceManager 处理调度器请求的线程数量
yarn.resourcemanager.scheduler.class 配置调度器

(2)Nodemanager 相关

yarn.nodemanager.resource.memory-mb NodeManager 使用内存数
yarn.nodemanager.resource.system-reserved-memory-mb NodeManager 为系统保留多少内存,和上一个参数二者取一即可
yarn.nodemanager.resource.cpu-vcores NodeManager 使用 CPU 核数
yarn.nodemanager.resource.count-logical-processors-as-cores 是否将虚拟核数当作 CPU 核数
yarn.nodemanager.resource.pcores-vcores-multiplier 虚拟核数和物理核数乘数,例如:4 核 8 线程,该参数就应设为 2
yarn.nodemanager.resource.detect-hardware-capabilities 是否让 yarn 自己检测硬件进行配置
yarn.nodemanager.pmem-check-enabled 是否开启物理内存检查限制 container
yarn.nodemanager.vmem-check-enabled 是否开启虚拟内存检查限制 container
yarn.nodemanager.vmem-pmem-ratio 虚拟内存物理内存比例

(3)Container 容器相关

yarn.scheduler.minimum-allocation-mb 容器最小内存
yarn.scheduler.maximum-allocation-mb 容器最大内存
yarn.scheduler.minimum-allocation-vcores 容器最小核数
yarn.scheduler.maximum-allocation-vcores 容器最大核数

2)参数具体使用案例
参考4.Hadoop之Yarn

10.Hadoop 综合调优

10.1 Hadoop 小文件优化方法

10.1.1 Hadoop 小文件弊端

HDFS 上每个文件都要在 NameNode 上创建对应的元数据,这个元数据的大小约为150byte,这样当小文件比较多的时候,就会产生很多的元数据文件,一方面会大量占用NameNode 的内存空间,另一方面就是元数据文件过多,使得寻址索引速度变慢
小文件过多,在进行 MR 计算时,会生成过多切片,需要启动过多的 MapTask。每个MapTask 处理的数据量小,导致 MapTask 的处理时间比启动时间还小,白白消耗资源。

10.1.2 Hadoop 小文件解决方案

1)在数据采集的时候,就将小文件或小批数据合成大文件再上传 HDFS(数据源头)
2)Hadoop Archive(存储方向)
是一个高效的将小文件放入 HDFS 块中的文件存档工具,能够将多个小文件打包成一个 HAR 文件,从而达到减少 NameNode 的内存使用
3)CombineTextInputFormat(计算方向)
CombineTextInputFormat 用于将多个小文件在切片过程中生成一个单独的切片或者少量的切片。
4)开启 uber 模式,实现 JVM 重用(计算方向)
默认情况下,每个 Task 任务都需要启动一个 JVM 来运行,如果 Task 任务计算的数据量很小,我们可以让同一个 Job 的多个 Task 运行在一个 JVM 中,不必为每个 Task 都开启一个 JVM。

(1)未开启 uber 模式,在/input 路径上上传多个小文件并执行 wordcount 程序

$ hadoop jar share/hadoop/mapreduce/hadoop-mapreduce-examples-3.1.3.jar wordcount /input /output3

(2)观察控制台
running in uber mode : false
(3)开启 uber 模式,在 mapred-site.xml 中添加如下配置

    
    
        mapreduce.job.ubertask.enable
        true
    
     
    
         mapreduce.job.ubertask.maxmaps
         9
    
    
    
         mapreduce.job.ubertask.maxreduces
         1
    
    
    
         mapreduce.job.ubertask.maxbytes
         
    

(5)分发配置
(6)再次执行 wordcount 程序

$ hadoop jar share/hadoop/mapreduce/hadoop-mapreduce-examples-3.1.3.jar wordcount /input /output4

(7)观察控制台

2022-04-03 13:38:58,433 INFO mapreduce.Job: Job job_1648966548024_0003 running in uber mode : true

10.2 测试 MapReduce 计算性能(虚拟机磁盘不够,未操作)

使用 Sort 程序评测 MapReduce
注:一个虚拟机不超过 150G 磁盘尽量不要执行这段代码
(1)使用 RandomWriter 来产生随机数,每个节点运行 10 个 Map 任务,每个 Map 产生大约 1G 大小的二进制随机数

$ hadoop jar /opt/module/hadoop-3.1.3/share/hadoop/mapreduce/hadoop-mapreduce-examples-3.1.3.jar randomwriter random-data

(2)执行 Sort 程序

$ hadoop jar /opt/module/hadoop-3.1.3/share/hadoop/mapreduce/hadoop-mapreduce-examples-3.1.3.jar sort random-data sorted-data

(3)验证数据是否真正排好序了

$ hadoop jar /opt/module/hadoop-3.1.3/share/hadoop/mapreduce/hadoop-mapreduce-client-jobclient-3.1.3-tests.jar testmapredsort -sortInput random-data -sortOutput sorted-data

10.3 企业开发场景案例

10.3.1 需求

(1)需求:从 1G 数据中,统计每个单词出现次数。服务器 3 台,每台配置 4G 内存,4 核 CPU,4 线程。
(2)需求分析:
1G / 128m = 8 个 MapTask;1 个 ReduceTask;1 个 mrAppMaster
平均每个节点运行 10 个 / 3 台 ≈ 3 个任务(4 3 3)

10.3.2 HDFS 参数调优

(1)修改:hadoop-env.sh

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

(2)修改 hdfs-site.xml



    dfs.namenode.handler.count
    27

(3)修改 core-site.xml



    fs.trash.interval
    60

(4)分发配置

10.3.3 MapReduce 参数调优

(1)修改 mapred-site.xml



     mapreduce.task.io.sort.mb
     100



     mapreduce.map.sort.spill.percent
     0.80



     mapreduce.task.io.sort.factor
     10



     mapreduce.map.memory.mb
     -1
 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.
 



     mapreduce.map.cpu.vcores
     1



     mapreduce.map.maxattempts
     4



     mapreduce.reduce.shuffle.parallelcopies
     5



     mapreduce.reduce.shuffle.input.buffer.percent
     0.70



     mapreduce.reduce.shuffle.merge.percent
     0.66



     mapreduce.reduce.memory.mb
     -1
 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. 



     mapreduce.reduce.cpu.vcores
     2



     mapreduce.reduce.maxattempts
     4



     mapreduce.job.reduce.slowstart.completedmaps
     0.05



     mapreduce.task.timeout
     600000

(2)分发配置

10.3.4 Yarn 参数调优

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



    The class to use as the resource scheduler.
    yarn.resourcemanager.scheduler.class
    org.apache.hadoop.yarn.server.resourcemanager.scheduler.capaci    ty.CapacityScheduler



    Number of threads to handle scheduler interface.
    yarn.resourcemanager.scheduler.client.thread-count
    8



    Enable auto-detection of node capabilities such as memory and CPU.
    yarn.nodemanager.resource.detect-hardware-capabilities
    false



    Flag to determine if logical processors(such ashyperthreads) should be counted a cores. Only applicable on Linux when yarn.nodemanager.resource.cpu-vcores is set to -1 and yarn.nodemanager.resource.detect-hardware-capabilities is true.
    yarn.nodemanager.resource.count-logical-processors-as-cores
    false



    Multiplier to determine how to convert phyiscal cores tovcores. 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. 
    yarn.nodemanager.resource.pcores-vcores-multiplier
    1.0



    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. 
    yarn.nodemanager.resource.memory-mb
    4096



    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.
    yarn.nodemanager.resource.cpu-vcores
    4



    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.
    yarn.scheduler.minimum-allocation-mb
    1024



    The maximum allocation for every container request at the  RM in MBs. Memory requests higher than this will throw an InvalidResourceRequestException. 
    yarn.scheduler.maximum-allocation-mb
    2048



    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.
    yarn.scheduler.minimum-allocation-vcores
    1



    The maximum allocation for every container request at the  RM in terms of virtual CPU cores. Requests higher than this will throw an InvalidResourceRequestException.
    yarn.scheduler.maximum-allocation-vcores
    2



    Whether virtual memory limits will be enforced for containers.
    yarn.nodemanager.vmem-check-enabled
    false



    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. 
    yarn.nodemanager.vmem-pmem-ratio
    2.1

(2)分发配置

$ xsync /opt/module/hadoop-3.1.3/etc/hadoop/

10.3.5 执行程序

(1)重启集群

$ myhadoop.sh stop
$ myhadoop.sh start

(2)执行 WordCount 程序

$ hadoop jar share/hadoop/mapreduce/hadoop-mapreduce-examples-3.1.3.jar wordcount /input /output5

(3)观察 Yarn 任务执行页面
http://testnode2:8088/cluster

你可能感兴趣的:(linux,hadoop,服务器,java)