hadoop HA集群搭建(亲测)

1.hadoop-env.sh

2.core-site.xml

<configuration>

            <!-- 指定hdfs的nameservice为ns1 -->

            <property>

                <name>fs.defaultFS</name>

                <value>hdfs://ns1/</value>

            </property>

            <!-- 指定hadoop临时目录 -->

            <property>

                <name>hadoop.tmp.dir</name>

                <value>/home/hadoop/app/hadoop-2.7.2/tmp</value>

            </property> 

            <!-- 指定zookeeper地址 -->

            <property>

                <name>ha.zookeeper.quorum</name>

               <value>spark05:2181,spark06:2181,spark07:2181</value>

            </property>

        </configuration>

3.hdfs-site.xml

<configuration>

    <!--指定hdfs的nameservice为ns1,需要和core-site.xml中的保持一致 -->

    <property>

        <name>dfs.nameservices</name>

        <value>ns1</value>

    </property>

    <!-- ns1下面有两个NameNode,分别是nn1,nn2 -->

    <property>

        <name>dfs.ha.namenodes.ns1</name>

        <value>nn1,nn2</value>

    </property>

    <!-- nn1的RPC通信地址 -->

    <property>

        <name>dfs.namenode.rpc-address.ns1.nn1</name>

        <value>spark01:9000</value>

    </property>

    <!-- nn1的http通信地址 -->

    <property>

        <name>dfs.namenode.http-address.ns1.nn1</name>

        <value>spark01:50070</value>

    </property>

    <!-- nn2的RPC通信地址 -->

    <property>

        <name>dfs.namenode.rpc-address.ns1.nn2</name>

        <value>spark02:9000</value>

    </property>

    <!-- nn2的http通信地址 -->

    <property>

        <name>dfs.namenode.http-address.ns1.nn2</name>

        <value>spark02:50070</value>

    </property>

    <!-- 指定NameNode的元数据在JournalNode上的存放位置 -->

    <property>

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

    <value>qjournal://spark05:8485;spark06:8485;spark07:8485/ns1</value>

    </property>

    <!-- 指定JournalNode在本地磁盘存放数据的位置 -->

    <property>

        <name>dfs.journalnode.edits.dir</name>

        <value>/home/hadoop/app/hadoop-2.7.2/journaldata</value>

    </property>

    <!-- 开启NameNode失败自动切换 -->

    <property>

        <name>dfs.ha.automatic-failover.enabled</name>

        <value>true</value>

    </property>

    <!-- 配置失败自动切换实现方式 -->

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

    </property>

    <!-- 配置隔离机制方法,多个机制用换行分割,即每个机制暂用一行-->

    <property>

        <name>dfs.ha.fencing.methods</name>

        <value>sshfence

                shell(/bin/true)

        </value>

    </property>

    <!-- 使用sshfence隔离机制时需要ssh免登陆 -->

    <property>

        <name>dfs.ha.fencing.ssh.private-key-files</name>

        <value>/home/hadoop/.ssh/id_rsa</value>

    </property>

    <!-- 配置sshfence隔离机制超时时间 -->

    <property>

        <name>dfs.ha.fencing.ssh.connect-timeout</name>

        <value>30000</value>

    </property>

</configuration>

3.mapred-site.xml

<configuration>

    <!-- 指定mr框架为yarn方式 -->

    <property>

        <name>mapreduce.framework.name</name>

        <value>yarn</value>

    </property>

</configuration>

4.yarn-site.xml

<configuration>

    <!-- 开启RM高可用 -->

    <property>                      <name>yarn.resourcemanager.ha.enabled</name>

        <value>true</value>

    </property>

    <!-- 指定RM的cluster id -->

    <property>

        <name>yarn.resourcemanager.cluster-id</name>

        <value>yrc</value>

    </property>

    <!-- 指定RM的名字 -->

    <property>

        <name>yarn.resourcemanager.ha.rm-ids</name>

        <value>rm1,rm2</value>

    </property>

    <!-- 分别指定RM的地址 -->

    <property>                         <name>yarn.resourcemanager.hostname.rm1</name>

       <value>spark03</value>

        </property>

    <property>                     <name>yarn.resourcemanager.hostname.rm2</name>

         <value>spark04</value>

    </property>

    <!-- 指定zk集群地址 -->

    <property>

        <name>yarn.resourcemanager.zk-address</name>                           <value>spark05:2181,spark06:2181,spark07:2181</value>

    </property>

    <property>

        <name>yarn.nodemanager.aux-services</name>

        <value>mapreduce_shuffle</value>

    </property>

</configuration>

5.slaves

spark05 

spark06 

spark07 

启动

1.启动三个zookeeper

2.启动三个journalnode

hadoop-daemon.sh start journalnode

3.格式化HDFS 

#在spark01上执行命令: 

hdfs namenode -format 

#格式化后会在根据core-site.xml中的hadoop.tmp.dir配置生成个文件,这里我配置的是/hadoop/hadoop-2.7.2/tmp,然后将/weekend/hadoop-2.4.1/tmp拷贝到hadoop02的/weekend/hadoop-2.7.2/下。 

scp -r tmp/ hadoop02:/home/hadoop/app/hadoop-2.7.2/ 

##也可以这样,建议hdfs namenode -bootstrapStandby 

4格式化ZKFC(在hadoop【spark】01上执行即可) 

hdfs zkfc -formatZK

5.启动HDFS(在hadoop【spark】01上执行) 

sbin/start-dfs.sh 

6.启动YARN(#####注意#####:是在spark03上执行start-yarn.sh,把namenode和resourcemanager分开是因为性能问题,因为他们都要占用大量资源,所以把他们分开了,他们分开了就要分别在不同的机器上启动) 

sbin/start-yarn.sh

然后手动启动第二个resourcemanager

yarn-daemon.sh start resourcemanager

7.在浏览器中查看nanenode 

http://node1:50070

http://node2:50070

8.验证HDFS HA 

首先向hdfs上传一个文件 

hadoop fs -put /etc/profile /profile 

hadoop fs -ls / 

然后再kill掉active的NameNode 

kill -9 

通过浏览器访问:http://192.168.1.202:50070 

NameNode ‘hadoop02:9000’ (active) 

这个时候weekend02上的NameNode变成了active 

9.在执行命令: 

hadoop fs -ls / 

-rw-r–r– 3 root supergroup 1926 2014-02-06 15:36 /profile 

刚才上传的文件依然存在!!! 

手动启动那个挂掉的NameNode 

sbin/hadoop-daemon.sh start namenode 

通过浏览器访问:http://192.168.1.201:50070 

NameNode ‘hadoop01:9000’ (standby) 

验证YARN: 

运行一下hadoop提供的demo中的WordCount程序: 

hadoop jar share/hadoop/mapreduce/hadoop-mapreduce-examples-2.4.1.jar wordcount /profile /out

1.hadoop-env.sh
2.core-site.xml<configuration>            <!-- 指定hdfs的nameservice为ns1 -->            <property>                <name>fs.defaultFS</name>                <value>hdfs://ns1/</value>            </property>            <!-- 指定hadoop临时目录 -->            <property>                <name>hadoop.tmp.dir</name>                <value>/home/hadoop/app/hadoop-2.7.2/tmp</value>            </property>             <!-- 指定zookeeper地址 -->            <property>                <name>ha.zookeeper.quorum</name>               <value>spark05:2181,spark06:2181,spark07:2181</value>            </property>        </configuration>


3.hdfs-site.xml<configuration>    <!--指定hdfs的nameservice为ns1,需要和core-site.xml中的保持一致 -->    <property>        <name>dfs.nameservices</name>        <value>ns1</value>    </property>    <!-- ns1下面有两个NameNode,分别是nn1,nn2 -->    <property>        <name>dfs.ha.namenodes.ns1</name>        <value>nn1,nn2</value>    </property>    <!-- nn1的RPC通信地址 -->    <property>        <name>dfs.namenode.rpc-address.ns1.nn1</name>        <value>spark01:9000</value>    </property>    <!-- nn1的http通信地址 -->    <property>        <name>dfs.namenode.http-address.ns1.nn1</name>        <value>spark01:50070</value>    </property>    <!-- nn2的RPC通信地址 -->    <property>        <name>dfs.namenode.rpc-address.ns1.nn2</name>        <value>spark02:9000</value>    </property>    <!-- nn2的http通信地址 -->    <property>        <name>dfs.namenode.http-address.ns1.nn2</name>        <value>spark02:50070</value>    </property>    <!-- 指定NameNode的元数据在JournalNode上的存放位置 -->    <property>        <name>dfs.namenode.shared.edits.dir</name>    <value>qjournal://spark05:8485;spark06:8485;spark07:8485/ns1</value>    </property>    <!-- 指定JournalNode在本地磁盘存放数据的位置 -->    <property>        <name>dfs.journalnode.edits.dir</name>        <value>/home/hadoop/app/hadoop-2.7.2/journaldata</value>    </property>    <!-- 开启NameNode失败自动切换 -->    <property>        <name>dfs.ha.automatic-failover.enabled</name>        <value>true</value>    </property>    <!-- 配置失败自动切换实现方式 -->    <property>                      <name>dfs.client.failover.proxy.provider.ns1</name>                     <value>org.apache.hadoop.hdfs.server.namenode.ha.ConfiguredFailoverProxyProvider</value>    </property>    <!-- 配置隔离机制方法,多个机制用换行分割,即每个机制暂用一行-->    <property>        <name>dfs.ha.fencing.methods</name>        <value>sshfence                shell(/bin/true)        </value>    </property>    <!-- 使用sshfence隔离机制时需要ssh免登陆 -->    <property>        <name>dfs.ha.fencing.ssh.private-key-files</name>        <value>/home/hadoop/.ssh/id_rsa</value>    </property>    <!-- 配置sshfence隔离机制超时时间 -->    <property>        <name>dfs.ha.fencing.ssh.connect-timeout</name>        <value>30000</value>    </property></configuration>
3.mapred-site.xml<configuration>    <!-- 指定mr框架为yarn方式 -->    <property>        <name>mapreduce.framework.name</name>        <value>yarn</value>    </property></configuration>
4.yarn-site.xml<configuration>    <!-- 开启RM高可用 -->    <property>                      <name>yarn.resourcemanager.ha.enabled</name>        <value>true</value>    </property>    <!-- 指定RM的cluster id -->    <property>        <name>yarn.resourcemanager.cluster-id</name>        <value>yrc</value>    </property>    <!-- 指定RM的名字 -->    <property>        <name>yarn.resourcemanager.ha.rm-ids</name>        <value>rm1,rm2</value>    </property>    <!-- 分别指定RM的地址 -->    <property>                         <name>yarn.resourcemanager.hostname.rm1</name>       <value>spark03</value>        </property>    <property>                     <name>yarn.resourcemanager.hostname.rm2</name>         <value>spark04</value>    </property>    <!-- 指定zk集群地址 -->    <property>        <name>yarn.resourcemanager.zk-address</name>                           <value>spark05:2181,spark06:2181,spark07:2181</value>    </property>    <property>        <name>yarn.nodemanager.aux-services</name>        <value>mapreduce_shuffle</value>    </property></configuration>

5.slavesspark05 spark06 spark07 

启动1.启动三个zookeeper
2.启动三个journalnodehadoop-daemon.sh start journalnode
3.格式化HDFS #在spark01上执行命令: hdfs namenode -format #格式化后会在根据core-site.xml中的hadoop.tmp.dir配置生成个文件,这里我配置的是/hadoop/hadoop-2.7.2/tmp,然后将/weekend/hadoop-2.4.1/tmp拷贝到hadoop02的/weekend/hadoop-2.7.2/下。 scp -r tmp/ hadoop02:/home/hadoop/app/hadoop-2.7.2/ ##也可以这样,建议hdfs namenode -bootstrapStandby  4格式化ZKFC(在hadoop【spark】01上执行即可) hdfs zkfc -formatZK
5.启动HDFS(在hadoop【spark】01上执行) sbin/start-dfs.sh 
6.启动YARN(#####注意#####:是在spark03上执行start-yarn.sh,把namenode和resourcemanager分开是因为性能问题,因为他们都要占用大量资源,所以把他们分开了,他们分开了就要分别在不同的机器上启动) sbin/start-yarn.sh
然后手动启动第二个resourcemanageryarn-daemon.sh start resourcemanager
7.在浏览器中查看nanenode http://node1:50070http://node2:50070
8.验证HDFS HA 首先向hdfs上传一个文件 hadoop fs -put /etc/profile /profile hadoop fs -ls / 然后再kill掉active的NameNode kill -9 通过浏览器访问:http://192.168.1.202:50070 NameNode ‘hadoop02:9000’ (active) 这个时候weekend02上的NameNode变成了active 
9.在执行命令: hadoop fs -ls / -rw-r–r– 3 root supergroup 1926 2014-02-06 15:36 /profile 刚才上传的文件依然存在!!! 手动启动那个挂掉的NameNode sbin/hadoop-daemon.sh start namenode 通过浏览器访问:http://192.168.1.201:50070 NameNode ‘hadoop01:9000’ (standby) 验证YARN: 运行一下hadoop提供的demo中的WordCount程序: hadoop jar share/hadoop/mapreduce/hadoop-mapreduce-examples-2.4.1.jar wordcount /profile /out

https://blog.csdn.net/u013821825/article/details/51377415

猜你喜欢

转载自www.cnblogs.com/ylht/p/11032451.html