Hadoop 配置文件解析

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



搭建Hadoop

1.1.复制编译后的hadoop项目到/usr/local目录下
1.2.修改位于etc/hadoop目录下的配置文件
1.2.1.hadoop-env.sh

export JAVA_HOME=/usr/local/jdk

1.2.2.core-site.xml

<configuration>
<property>
  <name>fs.defaultFS</name>
  <value>hdfs://cluster1</value>
</property>
【这里的值指的是默认的HDFS路径。当有多个HDFS集群同时工作时,用户如果不写集群名称,那么默认使用哪个哪?在这里指定!该值来自于hdfs-site.xml中的配置。在节点hadoop0和hadoop1中使用cluster1,在节点hadoop2和hadoop3中使用cluster2】

<property>
  <name>hadoop.tmp.dir</name>
  <value>/usr/local/hadoop/tmp</value>
</property>
【这里的路径默认是NameNode、DataNode、JournalNode等存放数据的公共目录。用户也可以自己单独指定这三类节点的目录。】
<property>
  <name>ha.zookeeper.quorum</name>
  <value>hadoop0:2181,hadoop1:2181,hadoop2:2181</value>
</property>
【这里是ZooKeeper集群的地址和端口。注意,数量一定是奇数,且不少于三个节点】
</configuration>


1.2.3.hdfs-site.xml  
该文件只配置在hadoop0和hadoop1上。
<configuration>
    <property>
        <name>dfs.replication</name>
        <value>2</value>
    </property>
【指定DataNode存储block的副本数量。默认值是3个,我们现在有4个DataNode,该值不大于4即可。】
    <property>
        <name>dfs.nameservices</name>
        <value>cluster1,cluster2</value>
    </property>
【使用federation时,使用了2个HDFS集群。这里抽象出两个NameService实际上就是给这2个HDFS集群起了个别名。名字可以随便起,相互不重复即可】
    <property>
        <name>dfs.ha.namenodes.cluster1</name>
        <value>hadoop0,hadoop1</value>
    </property>
【指定NameService是cluster1时的namenode有哪些,这里的值也是逻辑名称,名字随便起,相互不重复即可】
    <property>
        <name>dfs.namenode.rpc-address.cluster1.hadoop0</name>
        <value>hadoop0:9000</value>
    </property>
【指定hadoop0的RPC地址】
    <property>
        <name>dfs.namenode.http-address.cluster1.hadoop0</name>
        <value>hadoop0:50070</value>
    </property>
【指定hadoop0的http地址】
    <property>
        <name>dfs.namenode.rpc-address.cluster1.hadoop1</name>
        <value>hadoop1:9000</value>
    </property>
【指定hadoop1的RPC地址】
<property>
        <name>dfs.namenode.http-address.cluster1.hadoop1</name>
        <value>hadoop1:50070</value>
    </property>
【指定hadoop1的http地址】
    <property>
        <name>dfs.namenode.shared.edits.dir</name>
  <value>qjournal://hadoop0:8485;hadoop1:8485;hadoop2:8485/cluster1</value>
    </property>
【指定cluster1的两个NameNode共享edits文件目录时,使用的JournalNode集群信息】
<property>
        <name>dfs.ha.automatic-failover.enabled.cluster1</name>
        <value>true</value>
    </property>
【指定cluster1是否启动自动故障恢复,即当NameNode出故障时,是否自动切换到另一台NameNode】
<property>
        <name>dfs.client.failover.proxy.provider.cluster1</name>
     <value>org.apache.hadoop.hdfs.server.namenode.ha.ConfiguredFailoverProxyProvider</value>
    </property>
【指定cluster1出故障时,哪个实现类负责执行故障切换】
    <property>
        <name>dfs.ha.namenodes.cluster2</name>
        <value>hadoop2,hadoop3</value>
    </property>
【指定NameService是cluster2时,两个NameNode是谁,这里是逻辑名称,不重复即可。以下配置与cluster1几乎全部相似,不再添加注释】
    <property>
        <name>dfs.namenode.rpc-address.cluster2.hadoop2</name>
        <value>hadoop2:9000</value>
    </property>
    <property>
        <name>dfs.namenode.http-address.cluster2.hadoop2</name>
        <value>hadoop2:50070</value>
    </property>
    <property>
        <name>dfs.namenode.rpc-address.cluster2.hadoop3</name>
        <value>hadoop3:9000</value>
    </property>
    <property>
        <name>dfs.namenode.http-address.cluster2.hadoop3</name>
        <value>hadoop3: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>
<property>
        <name>dfs.journalnode.edits.dir</name>
        <value>/usr/local/hadoop/tmp/journal</value>
</property>
【指定JournalNode集群在对NameNode的目录进行共享时,自己存储数据的磁盘路径】
<property>
        <name>dfs.ha.fencing.methods</name>
        <value>sshfence</value>
    </property>
【一旦需要NameNode切换,使用ssh方式进行操作】
    <property>
        <name>dfs.ha.fencing.ssh.private-key-files</name>
        <value>/root/.ssh/id_rsa</value>
    </property>
【如果使用ssh进行故障切换,使用ssh通信时用的密钥存储的位置】
</configuration>


1.2.4.slaves
hadoop1
hadoop2
hadoop2
1.3.把以上配置的内容复制到hadoop1、hadoop2、hadoop3节点上

1.4.修改hadoop1、hadoop2、hadoop3上的配置文件内容
1.4.1.修改hadoop2上的core-site.xml内容
fs.defaultFS的值改为hdfs://cluster2
1.4.2.修改hadoop2上的hdfs-site.xml内容
把cluster1中关于journalnode的配置项删除,增加如下内容
<property>
    <name>dfs.namenode.shared.edits.dir</name>
<value>qjournal://hadoop0:8485;hadoop1:8485;hadoop2:8485/cluster2</value>
</property>
1.4.3.开始启动
1.4.3.1.启动journalnode
在hadoop0、hadoop1、hadoop2上执行sbin/hadoop-daemon.sh start journalnode
1.4.3.2.格式化ZooKeeper
在hadoop0、hadoop2上执行bin/hdfs  zkfc  -formatZK
1.4.3.3.对hadoop0节点进行格式化和启动
bin/hdfs  namenode  -format
sbin/hadoop-daemon.sh  start  namenode
1.4.3.4.对hadoop1节点进行格式化和启动 
bin/hdfs  namenode  -bootstrapStandby
sbin/hadoop-daemon.sh  start  namenode
1.4.3.5.在hadoop0、hadoop1上启动zkfc
sbin/hadoop-daemon.sh   start   zkfc
我们的hadoop0、hadoop1有一个节点就会变为active状态。
1.4.3.6.对于cluster2执行类似操作
1.4.4.启动datanode
在hadoop0上执行命令sbin/hadoop-daemons.sh   start   datanode

1.5.配置Yarn
1.5.1.修改文件mapred-site.xml
<property>
  <name>mapreduce.framework.name</name>
  <value>yarn</value>
</property> 


1.5.2. 修改文件yarn-site.xml
<property>
    <name>yarn.resourcemanager.hostname</name>
    <value>hadoop0</value>
</property>  
【自定ResourceManager的地址,还是单点,这是隐患】
<property>
    <name>yarn.nodemanager.aux-services</name>
    <value>mapreduce_shuffle</value>
 </property>


1.5.3.启动yarn
在hadoop0上执行sbin/start-yarn.sh

    
  • 大小: 15 KB
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Hadoop是一种基于Java的开源框架,用于处理和存储大规模数据集。要配置Hadoop环境,需要遵循以下步骤: 1. 安装Java Hadoop需要Java运行时环境才能运行。请确保已安装Java,并将JAVA_HOME环境变量设置为Java安装目录的路径。 2. 下载Hadoop 从Apache Hadoop的官方网站下载最新版本的Hadoop。 3. 解压缩HadoopHadoop文件解压缩到要安装Hadoop的目录。例如,将Hadoop解压缩到/opt/hadoop目录下。 4. 配置Hadoop 在/opt/hadoop/etc/hadoop目录下创建一个新文件,名为hadoop-env.sh。将以下行添加到文件中: export JAVA_HOME=/path/to/java 将/path/to/java替换为Java安装目录的路径。 在/opt/hadoop/etc/hadoop目录下创建一个新文件,名为core-site.xml。将以下行添加到文件中: <configuration> <property> <name>fs.defaultFS</name> <value>hdfs://localhost:9000</value> </property> </configuration> 此配置将默认文件系统设置为HDFS,并将其设置为localhost和端口号9000。 在/opt/hadoop/etc/hadoop目录下创建一个新文件,名为hdfs-site.xml。将以下行添加到文件中: <configuration> <property> <name>dfs.replication</name> <value>1</value> </property> </configuration> 此配置将数据复制因子设置为1,这意味着每个数据块只复制一次。 5. 启动Hadoop 启动Hadoop使用以下命令: $ /opt/hadoop/sbin/start-dfs.sh $ /opt/hadoop/sbin/start-yarn.sh 这将启动HDFS和YARN。 6. 测试Hadoop 在浏览器中输入http://localhost:50070/,将显示HDFS的Web界面。在命令行中输入以下命令来测试Hadoop: $ hadoop fs -mkdir /test $ hadoop fs -ls / 如果没有错误,则表示Hadoop已正确配置并正在运行。 以上是基本的Hadoop环境配置步骤,具体的配置可能会因为版本和操作系统的不同而有所不同。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值