zoukankan      html  css  js  c++  java
  • 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

  • 相关阅读:
    unomi漏洞复现
    xxl-job漏洞复现
    cgi漏洞复现
    celery漏洞复现
    bash漏洞复现
    学习ASP.NET的一些学习资源
    用EF DataBase First做一个简单的MVC3报名页面
    怎样在Word中插入代码并保持代码原始样式不变
    安装notepad++之后怎样在鼠标右键上加上Edit with notepad++
    安装Visual Studio 2010之后怎样安装MSDN Library
  • 原文地址:https://www.cnblogs.com/ylht/p/11032451.html
Copyright © 2011-2022 走看看