Hadoop2集群搭建

在这里我们选用4台机器进行示范,各台机器的职责如下表格所示

 

master

slave1

slave 2

slave 3

是NameNode吗?

是,属集群cluster1

是,属集群cluster1

是,属集群cluster2

是,属集群cluster2

是DataNode吗?

是JournalNode吗?

是ZooKeeper吗?

是ZKFC吗?

 

搭建自动HA

A.      复编制译后的hadoop项目到/usr/local目录下

B.       修改位于etc/hadoop目录下的配置文件

a)       hadoop-env.sh

export JAVA_HOME=/usr/local/Java/jdk7

b)       core-site.xml

<configuration>    

<!--这里的值指的是默认的HDFS路径。当有多个HDFS集群同时工作时,用户如果不写集群名称,那么默认使用哪个哪?在这里指定!该值来自于hdfs-site.xml中的配置。在节点hadoop0hadoop1中使用cluster1,在节点hadoop2hadoop3中使用cluster2-->

<property>
  <name>fs.defaultFS</name>
 <value>hdfs://cluster1</value>
</property>

 

<!--这里的路径默认是NameNodeDataNodeJournalNode等存放数据的公共目录。用户也可以自己单独指定这三类节点的目录。-->

<property>
  <name>hadoop.tmp.dir</name>
  <value>/usr/local/hadoop-2.6.3/tmp</value>
</property>

 

<!--这里是ZooKeeper集群的地址和端口。注意,数量一定是奇数,且不少于三个节点。-->

<property>
  <name>ha.zookeeper.quorum</name>
  <value>master:2181,slave1:2181,slave2:2181</value>
</property>

</configuration>

c)        hdfs-site.xml  

<!--该文件只配置在cluster1集群的机器上。-->

<configuration>

<!--指定DataNode存储block的副本数量。默认值是3个,我们现在有4DataNode,该值不大于4即可。-->

<property>
        <name>dfs.replication</name>
        <value>2</value>
    </property>

 

<!--使用federation时,使用了2HDFS集群。这里抽象出两个NameService实际上就是给这2HDFS集群起了个别名。名字可以随便起,相互不重复即可。-->

<property>
       <name>dfs.nameservices</name>
       <value>cluster1,cluster2</value>
    </property>

 

<!--指定NameServicecluster1时的namenode有哪些,这里的值也是逻辑名称,名字随便起,相互不重复即可-->
   <property>
       <name>dfs.ha.namenodes.cluster1</name>
        <value>master,slave1</value>
    </property>

 

<!--指定cluster1的节点masterRPC地址-->
    <property>
        <name>dfs.namenode.rpc-address.cluster1.master</name>
        <value>master:9000</value>
    </property>

 

<!--指定cluster1的节点masterHTTP地址-->
    <property>
       <name>dfs.namenode.http-address.cluster1. master </name>
        <value> master:50070</value>
    </property>

 

<!--指定cluster1的节点slave1RPC地址-->
    <property>
       <name>dfs.namenode.rpc-address.cluster1.slave1</name>
        <value> slave1:9000</value>
    </property>

 

<!--指定cluster1的节点slave1HTTP地址-->

<property>
       <name>dfs.namenode.http-address.cluster1. slave1</name>
        <value> slave1:50070</value>
    </property>


 <!--指定cluster1的两个NameNode共享edits文件目录时,使用的JournalNode集群信息-->  

      <property>
       <name>dfs.namenode.shared.edits.dir</name>
             <value>qjournal://hadoop0:8485;hadoop1:8485;hadoop2:8485/cluster1</value>
    </property>

<!--指定cluster1是否启动自动故障恢复,即当NameNode出故障时,是否自动切换到另一台NameNode-->

<property>
       <name>dfs.ha.automatic-failover.enabled.cluster1</name>
        <value>true</value>
    </property>

<!--指定cluster1出故障时,哪个实现类负责执行故障切换-->

<property>
       <name>dfs.client.failover.proxy.provider.cluster1</name>                                     <value>org.apache.hadoop.hdfs.server.namenode.ha.ConfiguredFailoverProxyProvider</value>

 </property>

 

<!--指定NameServicecluster2时,两个NameNode是谁,这里是逻辑名称,不重复即可。以下配置与cluster1几乎全部相似,不再添加注释-->
    <property>
       <name>dfs.ha.namenodes.cluster2</name>
        <value>slave2,slave3</value>
    </property>

   <property>
       <name>dfs.namenode.rpc-address.cluster2. slave2</name>
        <value> slave2:9000</value>
    </property>
    <property>
        <name>dfs.namenode.http-address.cluster2.slave2</name>
        <value> slave2:50070</value>
    </property>
    <property>
       <name>dfs.namenode.rpc-address.cluster2. slave3</name>
        <value> slave3:9000</value>
    </property>

<property>
        <name>dfs.namenode.http-address.cluster2.slave3</name>
        <value> slave3:50070</value>
    </property>

 

<!--这段代码是注释掉的,不要打开-->
    <!--
    <property>
       <name>dfs.namenode.shared.edits.dir</name>
       <value>qjournal://hadoop0:8485;hadoop1:8485;hadoop2:8485/cluster2</value>
    </property>
    -->


<property>
       <name>dfs.ha.automatic-failover.enabled.cluster2</name>
        <value>true</value>
</property>
<property>
    <name>dfs.client.failover.proxy.provider.cluster2</name>

<value>org.apache.hadoop.hdfs.server.namenode.ha.ConfiguredFailoverProxyProvider</value>
</property>

 

<!--指定JournalNode集群在对NameNode的目录进行共享时,自己存储数据的磁盘路径-->

<property>
       <name>dfs.journalnode.edits.dir</name>
        <value>/usr/local/hadoop-2.6.3/tmp/journal</value>
</property>

 

<!--一旦需要NameNode切换,使用ssh方式进行操作-->

<property>
       <name>dfs.ha.fencing.methods</name>
       <value>sshfence</value>
    </property>

 

<!--如果使用ssh进行故障切换,使用ssh通信时用的密钥存储的位置-->

   <property>
       <name>dfs.ha.fencing.ssh.private-key-files</name>
       <value>/root/.ssh/id_rsa</value>
    </property>

</configuration>

 

d)       修改配置文件slaves,添加datanode节点域名

slave1

slave2

slave3

C.       把以上配置的内容复制到slave 1、slave 2、slave 3节点上

D.      修改cluster2集群上的节点slave2、slave3的配置文件内容

a)        修改slave2上的core-site.xml

fs.defaultFS的值改为hdfs://cluster2

b)       修改slave2上的hdfs-site.xml内容

把cluster1中关于journalnode的配置项删除,在配置地址属性下增加如下内容

<property>

   <name>dfs.namenode.shared.edits.dir</name>

<value>qjournal://master:8485; slave1:8485; slave2:8485/cluster2</value>

</property>

开始启动

A.      首先启动zookeeper集群

在master、slave1、slave2上执行zkServer.sh start

B.       启动journalnode

在master、slave1、slave2上执行sbin/hadoop-daemon.sh startjournalnode

C.       格式化ZooKeeper

在不同集群cluster1,cluster2的namenode节点(master,slave2) 执行bin/hdfs  zkfc  -formatZK

D.      对master节点进行格式化和启动

bin/hdfs  namenode -format

sbin/hadoop-daemon.sh start  namenode

E.       对slave1节点进行格式化和启动 

bin/hdfs  namenode -bootstrapStandby

sbin/hadoop-daemon.sh start  namenode

F.       在cluster1集群机器master、slave1上启动zkfc

sbin/hadoop-daemon.sh   start  zkfc

 

<!—cluster1集群上的masterslave1中某个节点就会变为active状态。-->

 

对于cluster2执行类似D-F操作

A.      启动datanode

在master上执行命令sbin/hadoop-daemons.sh   start  datanode

B.       配置Yarn

a)        修改文件mapred-site.xml

<property>
 <name>mapreduce.framework.name</name>
  <value>yarn</value>
</property>

b)        修改文件yarn-site.xml

<!--自定ResourceManager的地址,还是单点,这是隐患-->

<property>
   <name>yarn.resourcemanager.hostname</name>
    <value>master</value>
 </property>  

<property>
           <name>yarn.nodemanager.aux-services</name>
           <value>mapreduce_shuffle</value>
 </property>

 

C.       启动yarn

在master上执行sbin/start-yarn.sh          

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值