(转)关于机架感知(RackAwareness)
一、背景
分布式的集群通常包含非常多的机器,由于受到机架槽位和交换机网口的限制,通常大型的分布式集群都会跨好几个机架,由多个机架上的机器共同组成一个分布式集群。机架内的机器之间的网络速度通常都会高于跨机架机器之间的网络速度,并且机架之间机器的网络通信通常受到上层交换机间网络带宽的限制。
在这种情况下,
-
希望不同节点之间的通信能够尽量发生在同一个机架之内,而不是跨机架。
-
为了提高容错能力,名称节点会尽可能把数据块的副本放到多个机架上。
综合考虑这两点的基础上Hadoop设计了机架感知功能。
二、什么是机架感知
机架感知是一种计算不同计算节点(TaskTracker)的距离的技术,用以在任务调度过程中尽量减少网络带宽资源的消耗,这里用尽量,想表达的是当一个TT(TaskTracker)申请不到本地化任务时,JT(JobTracker)会尽量调度一个机架的任务给他,因为不同机架的网络带宽资源比同一个机架的网络带宽资源更可贵。
三、机架感知设计思想
首先,一个重要的假设前提是HDFS运行于一个具有树状网络拓扑结构的集群上。例如集群由多个数据中心组成,每个数据中心里有多个机架,而每个机架上有多台计算机(数据节点)。如下图所示:
网络拓扑(NetworkTopology)
在Hadoop里,以类似于一种文件目录结构的方式来表示节点。
例如,R1的位置可以表示为 /D1/R1,而H12的位置可以表示为 /D2/R4/H12。
当DataNode启动的时候,需要通过一种机制来明确它在集群中的位置,才能构建完整的网络拓扑图。
因此,首先它需要确认它的上级节点(通常也就是机架)的位置。数据节点程序支持选项”-p<id>”或”-parent<id>”从命令行读入上级节点位置。
如果没有指定这个选项,那么会使用一个默认的上级节点。
至于如何获取上级节点信息,由实施Hadoop的机构自行决定。一个常用的做法是使用脚本打印当前机器的上级节点信息到标准输出stdout。
这样DataNode启动的时候就可以获取到上级节点的信息(Hadoop应该是通过接口’DNSToSwitchMapping’来解析这个信息,具体请参考手册的Class说明)。
DataNode会把它的位置信息发给NameNode。
当NameNode收到DataNode的位置信息以后,它会先检查网络拓扑中是否已经有这个DataNode的记录。
如果有,它会把旧的记录删除,加入新的节点位置信息。
副本放置(ReplicaPlacement)
数据块的副本放置策略的目的是在以下两者之间取得平衡:
- 使数据的可靠性和可用性较大化
- 使写入数据产生的开销最小化
因此,当一个新的数据块被创建的时候,遵循以下规则:
- 第1个副本放置于本地节点
- 第2个副本放置于不同的机架
- 第3个副本放置于本地机架的不同节点
其余的副本在遵循以下限制的前提下随机放置
- 1个节点最多放置1个副本
- 如果副本数少于2倍机架数,不可以在同一机架放置超过2个副本
当重新复制一个数据块的时候,遵循以下规则:
- 如果已有1个副本,把第2个副本放置在不同的机架
- 如果已有2个副本且处于同一机架,把第3个副本放置在不同的机架
- 如果已有2个副本但不处于同一机架,把第3个副本放置在和第1个副本相同的机架
- 当可用副本数超过2个的时候,随机放置
当发生数据读取的时候,NameNode首先检查客户端是否位于集群中。
如果是的话,就可以按照由近到远的优先次序决定由哪个DataNode向客户端发送它需要的数据块。
也就是说,对于拥有同一数据块副本的节点来说,在网络拓扑中距离客户端近的节点会优先响应。