处理数据时,hadoop如何找最近的数据节点呢?

首先,namenode维护着当前集群中datanode的拓扑情况(也就是哪个datanode在哪个机架上)。
hadoop认为datanode与客户端的距离,最近的是客户端本身(如果客户端与datanode在同一台机器上时),
其次是与客户端在同一机架上的datanode,最远的是与客户端在不同机架上的datanode。
1)如果客户端在集群中,namenode就可以从数据所在datanode中,选出一个距离最短的节点了。
2)如果客户端不在集群中时,namenode认为客户端与集群中任何datanode的距离是一样的,
namenode会根据datanode负载情况,返回一个拥有数据的datanode的位置信息,供客户端访问它。  
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值