HDFS机架感知配置(block放置策略/NodeGroup分配策略配置)

HDFS机架感知配置(block放置策略/NodeGroup分配策略配置)

1、配置hdfs-site和core-site文件

  • core-site.xml
<property>
    <name>net.topology.impl</name>
    <value>org.apache.hadoop.net.NetworkTopologyWithNodeGroup</value>
</property>
<property>
    <name>net.topology.script.file.name</name>
    <value>/tmp/rack.py</value>	
</property>
<property>
    <name>net.topology.nodegroup.aware</name>
    <value>true</value>
</property>
  • hdfs-site.xml
<property>
    <name>dfs.block.replicator.classname</name>
    <value>
        org.apache.hadoop.hdfs.server.blockmanagement.BlockPlacementPolicyWithNodeGroup
    </value>
</property>
<property>
    <name>dfs.use.dfs.network.topology</name>
    <value>false</value>
</property>

2、nodegroup示例

192.168.0.1 /rack1/nodegroup1
192.168.0.2 /rack1/nodegroup1
192.168.0.3 /rack1/nodegroup2
192.168.0.4 /rack1/nodegroup2
192.168.0.5 /rack2/nodegroup3
192.168.0.6 /rack2/nodegroup3

添加脚本

#!/usr/bin/python
# -*- coding: UTF-8 -*-
import sys
rack = {
    "192.168.0.1": "/rack1/nodegroup1",
    "192.168.0.2": "/rack1/nodegroup1",
    "192.168.0.3": "/rack1/nodegroup2",
    "192.168.0.4": "/rack1/nodegroup2",
    "192.168.0.5": "/rack2/nodegroup3",
    "192.168.0.6": "/rack2/nodegroup3",
}
if __name__ == "__main__":
    if len(sys.argv) < 2:
        sys.exit(1)
        ip_address = sys.argv[1]
        result = rack.get(ip_address, "/default-rack")
        print(result)

给脚本授权

chmod +777 /tmp/rack.py

3、通过命令查看是否配置成功

hdfs dfsadmin -printTopology
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值