hdfs的HA集羣搭建的相關配置

前期準備就不詳細說了
1.修改Linux主機名
2.修改IP
3.修改主機名和IP的映射關係
    ######注意######若是大家公司是租用的服務器或是使用的雲主機(如華爲用主機、阿里雲主機等)
    /etc/hosts裏面要配置的是內網IP地址和主機名的映射關係    
4.關閉防火牆
5.ssh免登錄
6.安裝JDK,配置環境變量等

集羣規劃:
    主機名        IP                安裝的軟件                    運行的進程
    server01    192.168.1.201    jdk、hadoop                    NameNode、DFSZKFailoverController(zkfc)
    server02    192.168.1.202    jdk、hadoop                    NameNode、DFSZKFailoverController(zkfc)
    server03    192.168.1.203    jdk、hadoop                    ResourceManager
    server04    192.168.1.204    jdk、hadoop                    ResourceManager
    server05    192.168.1.205    jdk、hadoop、zookeeper        DataNode、NodeManager、JournalNode、QuorumPeerMain
    server06    192.168.1.206    jdk、hadoop、zookeeper        DataNode、NodeManager、JournalNode、QuorumPeerMain
    server07    192.168.1.207    jdk、hadoop、zookeeper        DataNode、NodeManager、JournalNode、QuorumPeerMain
    
說明:
    1.在hadoop2.0中一般由兩個NameNode組成,一個處於active狀態,另外一個處於standby狀態。Active NameNode對外提供服務,而Standby NameNode則不對外提供服務,僅同步active namenode的狀態,以便可以在它失敗時快速進行切換。
    hadoop2.0官方提供了兩種HDFS HA的解決方案,一種是NFS,另外一種是QJM。這裏咱們使用簡單的QJM。在該方案中,主備NameNode之間經過一組JournalNode同步元數據信息,一條數據只要成功寫入多數JournalNode即認爲寫入成功。一般配置奇數個JournalNode
    這裏還配置了一個zookeeper集羣,用於ZKFC(DFSZKFailoverController)故障轉移,當Active NameNode掛掉了,會自動切換Standby NameNode爲standby狀態
    2.hadoop-2.2.0中依然存在一個問題,就是ResourceManager只有一個,存在單點故障,hadoop-2.4.1解決了這個問題,有兩個ResourceManager,一個是Active,一個是Standby,狀態由zookeeper進行協調
安裝步驟:
    1.安裝配置zooekeeper集羣(在server05上)
        1.1解壓
            tar -zxvf zookeeper-3.4.5.tar.gz -C /server/
        1.2修改配置
            cd /server/zookeeper-3.4.5/conf/
            cp zoo_sample.cfg zoo.cfg
            vim zoo.cfg
            修改:dataDir=/server/zookeeper-3.4.5/tmp
            在最後添加:
            server.1=server05:2888:3888
            server.2=server06:2888:3888
            server.3=server07:2888:3888
            保存退出
            而後建立一個tmp文件夾
            mkdir /server/zookeeper-3.4.5/tmp
            再建立一個空文件
            touch /server/zookeeper-3.4.5/tmp/myid
            最後向該文件寫入ID
            echo 1 > /server/zookeeper-3.4.5/tmp/myid
        1.3將配置好的zookeeper拷貝到其餘節點(首先分別在server0六、server07根目錄下建立一個server目錄:mkdir /server)
            scp -r /server/zookeeper-3.4.5/ server06:/server/
            scp -r /server/zookeeper-3.4.5/ server07:/server/
            
            注意:修改server0六、server07對應/server/zookeeper-3.4.5/tmp/myid內容
            server06:
                echo 2 > /server/zookeeper-3.4.5/tmp/myid
            server07:
                echo 3 > /server/zookeeper-3.4.5/tmp/myid
    
    2.安裝配置hadoop集羣(在server01上操做)
        2.1解壓
            tar -zxvf hadoop-2.4.1.tar.gz -C /server/
        2.2配置HDFS(hadoop2.0全部的配置文件都在$HADOOP_HOME/etc/hadoop目錄下)
            #將hadoop添加到環境變量中
            vim /etc/profile
            export JAVA_HOME=/usr/java/jdk1.7.0_55
            export HADOOP_HOME=/server/hadoop-2.4.1
            export PATH=$PATH:$JAVA_HOME/bin:$HADOOP_HOME/bin
            
            #hadoop2.0的配置文件所有在$HADOOP_HOME/etc/hadoop下
            cd /home/hadoop/app/hadoop-2.4.1/etc/hadoop
            
            2.2.1修改hadoo-env.sh
                export JAVA_HOME=/home/hadoop/app/jdk1.7.0_55
                
            2.2.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.4.1/tmp</value>
                    </property>
                    
                    <!-- 指定zookeeper地址 -->
                    <property>
                        <name>ha.zookeeper.quorum</name>
                        <value>server05:2181,server06:2181,server07:2181</value>
                    </property>
                </configuration>
                
            2.2.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>server01:9000</value>
                    </property>
                    <!-- nn1的http通訊地址 -->
                    <property>
                        <name>dfs.namenode.http-address.ns1.nn1</name>
                        <value>server01:50070</value>
                    </property>
                    <!-- nn2的RPC通訊地址 -->
                    <property>
                        <name>dfs.namenode.rpc-address.ns1.nn2</name>
                        <value>server02:9000</value>
                    </property>
                    <!-- nn2的http通訊地址 -->
                    <property>
                        <name>dfs.namenode.http-address.ns1.nn2</name>
                        <value>server02:50070</value>
                    </property>
                    <!-- 指定NameNode的元數據在JournalNode上的存放位置 -->
                    <property>
                        <name>dfs.namenode.shared.edits.dir</name>
                        <value>qjournal://server05:8485;server06:8485;server07:8485/ns1</value>
                    </property>
                    <!-- 指定JournalNode在本地磁盤存放數據的位置 -->
                    <property>
                        <name>dfs.journalnode.edits.dir</name>
                        <value>/home/hadoop/app/hadoop-2.4.1/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>
            
            2.2.4修改mapred-site.xml
                <configuration>
                    <!-- 指定mr框架爲yarn方式 -->
                    <property>
                        <name>mapreduce.framework.name</name>
                        <value>yarn</value>
                    </property>
                </configuration>    
            
            2.2.5修改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>server03</value>
                        </property>
                        <property>
                           <name>yarn.resourcemanager.hostname.rm2</name>
                           <value>server04</value>
                        </property>
                        <!-- 指定zk集羣地址 -->
                        <property>
                           <name>yarn.resourcemanager.zk-address</name>
                           <value>server05:2181,server06:2181,server07:2181</value>
                        </property>
                        <property>
                           <name>yarn.nodemanager.aux-services</name>
                           <value>mapreduce_shuffle</value>
                        </property>
                </configuration>
            
                
            2.2.6修改slaves(slaves是指定子節點的位置,由於要在server01上啓動HDFS、在server03啓動yarn,因此server01上的slaves文件指定的是datanode的位置,server03上的slaves文件指定的是nodemanager的位置)
                server05
                server06
                server07

            2.2.7配置免密碼登錄
                #首先要配置server01到server0二、server0三、server0四、server0五、server0六、server07的免密碼登錄
                #在server01上生產一對鑰匙
                ssh-keygen -t rsa
                #將公鑰拷貝到其餘節點,包括本身
                ssh-coyp-id server01
                ssh-coyp-id server02
                ssh-coyp-id server03
                ssh-coyp-id server04
                ssh-coyp-id server05
                ssh-coyp-id server06
                ssh-coyp-id server07
                #配置server03到server0四、server0五、server0六、server07的免密碼登錄
                #在server03上生產一對鑰匙
                ssh-keygen -t rsa
                #將公鑰拷貝到其餘節點
                ssh-coyp-id server04
                ssh-coyp-id server05
                ssh-coyp-id server06
                ssh-coyp-id server07
                #注意:兩個namenode之間要配置ssh免密碼登錄,別忘了配置server02到server01的免登錄
                在server02上生產一對鑰匙
                ssh-keygen -t rsa
                ssh-coyp-id -i server01                
        
        2.4將配置好的hadoop拷貝到其餘節點
            scp -r /server/ server02:/
            scp -r /server/ server03:/
            scp -r /server/hadoop-2.4.1/ hadoop@server04:/server/
            scp -r /server/hadoop-2.4.1/ hadoop@server05:/server/
            scp -r /server/hadoop-2.4.1/ hadoop@server06:/server/
            scp -r /server/hadoop-2.4.1/ hadoop@server07:/server/
        ###注意:嚴格按照下面的步驟
        2.5啓動zookeeper集羣(分別在server0五、server0六、tcast07上啓動zk)
            cd /server/zookeeper-3.4.5/bin/
            ./zkServer.sh start
            #查看狀態:一個leader,兩個follower
            ./zkServer.sh status
            
        2.6啓動journalnode(分別在在server0五、server0六、tcast07上執行)
            cd /server/hadoop-2.4.1
            sbin/hadoop-daemon.sh start journalnode
            #運行jps命令檢驗,server0五、server0六、server07上多了JournalNode進程
        
        2.7格式化HDFS
            #在server01上執行命令:
            hdfs namenode -format
            #格式化後會在根據core-site.xml中的hadoop.tmp.dir配置生成個文件,這裏我配置的是/server/hadoop-2.4.1/tmp,而後將/server/hadoop-2.4.1/tmp拷貝到server02的/server/hadoop-2.4.1/下。
            scp -r tmp/ server02:/home/hadoop/app/hadoop-2.4.1/
            ##也能夠這樣,建議hdfs namenode -bootstrapStandby
        
        2.8格式化ZKFC(在server01上執行便可)
            hdfs zkfc -formatZK
        
        2.9啓動HDFS(在server01上執行)
            sbin/start-dfs.sh

        2.10啓動YARN(#####注意#####:是在server03上執行start-yarn.sh,把namenode和resourcemanager分開是由於性能問題,由於他們都要佔用大量資源,因此把他們分開了,他們分開了就要分別在不一樣的機器上啓動)
            sbin/start-yarn.sh

        
    到此,hadoop-2.4.1配置完畢,能夠統計瀏覽器訪問:
        http://192.168.1.201:50070
        NameNode 'server01:9000' (active)
        http://192.168.1.202:50070
        NameNode 'server02:9000' (standby)
    
    驗證HDFS HA
        首先向hdfs上傳一個文件
        hadoop fs -put /etc/profile /profile
        hadoop fs -ls /
        而後再kill掉active的NameNode
        kill -9 <pid of NN>
        經過瀏覽器訪問:http://192.168.1.202:50070
        NameNode 'server02:9000' (active)
        這個時候server02上的NameNode變成了active
        在執行命令:
        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 'server01:9000' (standby)
    
    驗證YARN:
        運行一下hadoop提供的demo中的WordCount程序:
        hadoop jar share/hadoop/mapreduce/hadoop-mapreduce-examples-2.4.1.jar wordcount /profile /out
    
    OK,大功告成!!!

    
            
        
測試集羣工做狀態的一些指令 :
bin/hdfs dfsadmin -report     查看hdfs的各節點狀態信息


bin/hdfs haadmin -getServiceState nn1         獲取一個namenode節點的HA狀態

sbin/hadoop-daemon.sh start namenode  單獨啓動一個namenode進程


./hadoop-daemon.sh start zkfc   單獨啓動一個zkfc進程
            


注意手動代替zkfc可能致使split-brain

腦裂:原本一個大腦的兩半球互相配合,變成了分裂成兩個獨立的大腦,都認爲對方已死。在集羣環境中,有這麼幾種可能形成"Split-Brain"現象:java

 
 

        一、在集羣環境中的節點間的心跳線同時斷掉後,集羣系統所處於的一種特殊狀態。例如節點1和2組成一個集羣,忽然1和2間的心跳同時都斷了,若是此前節點1正在運行應用,心跳都斷掉後2開始去接管應用,強行加載數據,此時就是split-brain。node

 
 

       二、集羣中節點由於處理器忙或者其餘緣由暫時中止響應時,其餘節點可能誤認爲該節點「已死」。shell

 
 

後果:節點間爭奪共享磁盤(即資源)的訪問權,都對共享文件系統產生讀寫操做,從而致使共享磁盤文件系統損壞。 apache

 
 

解決辦法:使用硬盤心跳,scsi reservation,以及最極端的power fence。bootstrap

相關文章
相關標籤/搜索