设为首页 - 加入收藏 ASP站长网(Aspzz.Cn)- 科技、建站、经验、云计算、5G、大数据,站长网!
热搜: 重新 试卷 创业者
当前位置: 首页 > 运营中心 > 建站资源 > 优化 > 正文

Hadoop之完全分布式集群(2)

发布时间:2019-09-26 22:25 所属栏目:21 来源:kocdaniel
导读:配置yarn-env.sh [kocdaniel@hadoop102hadoop]$vimyarn-env.sh exportJAVA_HOME=/opt/module/jdk1.8.0_144 配置yarn-site.xml [kocdaniel@hadoop102hadoop]$viyarn-site.xml #增加如下配置 !--Reducer获取数据的方

配置yarn-env.sh

  1. [kocdaniel@hadoop102 hadoop]$ vim yarn-env.sh 
  2. export JAVA_HOME=/opt/module/jdk1.8.0_144 

配置yarn-site.xml

  1. [kocdaniel@hadoop102 hadoop]$ vi yarn-site.xml 
  2. # 增加如下配置 
  3. <!-- Reducer获取数据的方式 --> 
  4. <property> 
  5.         <name>yarn.nodemanager.aux-services</name> 
  6.         <value>mapreduce_shuffle</value> 
  7. </property> 
  8.  
  9. <!-- 指定YARN的ResourceManager的地址 --> 
  10. <property> 
  11.         <name>yarn.resourcemanager.hostname</name> 
  12.         <value>hadoop103</value> 
  13. </property> 
  • MapReduce配置文件

配置mapred-env.sh

  1. [kocdaniel@hadoop102 hadoop]$ vim mapred-env.sh 
  2. export JAVA_HOME=/opt/module/jdk1.8.0_144 

配置mapred-site.xml

  1. # 如果是第一次配置的话,需要先将mapred-site.xml.template重命名为mapred-site.xml 
  2. [kocdaniel@hadoop102 hadoop]$ cp mapred-site.xml.template mapred-site.xml 
  3. [kocdaniel@hadoop102 hadoop]$ vim mapred-site.xml 
  4. # 在文件中增加如下配置 
  5. <!-- 指定MR运行在Yarn上 --> 
  6. <property> 
  7.         <name>mapreduce.framework.name</name> 
  8.         <value>yarn</value> 
  9. </property> 

3.将配置好的文件利用集群分发脚本同步到hadoop103和hadoop104节点

  1. [kocdaniel@hadoop102 hadoop]$ xsync /opt/module/hadoop-2.7.2/ 
  • 最好在同步完成之后检查一下同步结果,避免错误

单点启动

1.如果是第一次启动,需要格式化namenode,否则跳过此步

  1. [kocdaniel@hadoop102 hadoop-2.7.2]$ hadoop namenode -format 
  • 格式化需要注意的问题:
  1. 只有第一次启动需要格式化,以后不要总是格式化,否则会出现namenode和datanode的集群id不一致的情况,导致datanode启动失败
  2. 正确的格式化姿势:
  • 在执行第一次格式化时会在hadoop安装目录下产生data文件夹,里面会生成namenode的信息
  • 在启动namenode和datanode后,还会在同样的目录下产生logs的日志文件夹
  • 所以在格式化之前需要先将这两个文件夹删除,然后再格式化,最后启动namenode和datanode

2.在hadoop102上启动namenode

  1. [kocdaniel@hadoop102 hadoop-2.7.2]$ hadoop-daemon.sh start namenode 
  2. [kocdaniel@hadoop102 hadoop-2.7.2]$ jps 
  3. 3461 NameNode 

3.在hadoop102、hadoop103以及hadoop104上分别启动DataNode

  1. [kocdaniel@hadoop102 hadoop-2.7.2]$ hadoop-daemon.sh start datanode 
  2. [kocdaniel@hadoop102 hadoop-2.7.2]$ jps 
  3. 3461 NameNode 
  4. 3608 Jps 
  5. 3561 DataNode 
  6. [kocdaniel@hadoop103 hadoop-2.7.2]$ hadoop-daemon.sh start datanode 
  7. [kocdaniel@hadoop103 hadoop-2.7.2]$ jps 
  8. 3190 DataNode 
  9. 3279 Jps 
  10. [kocdaniel@hadoop104 hadoop-2.7.2]$ hadoop-daemon.sh start datanode 
  11. [kocdaniel@hadoop104 hadoop-2.7.2]$ jps 
  12. 3237 Jps 
  13. 3163 DataNode 

4.访问hadoop102:50070查看结果

  • 但是以上单点启动有一个问题:

每次都一个一个节点启动,如果节点数增加到1000个怎么办?

配置ssh免密登录

1.配置ssh

ssh 另一个节点的ip 就可以切换到另一台机器,但是得输入密码

2.免密ssh配置

免密登录原理

Hadoop之完全分布式集群

  • 在配置namenode的主机hadoop102上生成私钥和公钥

切换目录到/home/用户名/.ssh/

  1. [kocdaniel@hadoop102 .ssh]$ ssh-keygen -t rsa 
  1. - 然后敲(三个回车),就会生成两个文件id_rsa(私钥)、id_rsa.pub(公钥) 
  2.  - 将公钥拷贝到要免密登录的目标机器上 
  3.  
  4.  ```shell 
  5.  [kocdaniel@hadoop102 .ssh]$ ssh-copy-id hadoop103 
  6.  [kocdaniel@hadoop102 .ssh]$ ssh-copy-id hadoop104 
  7.  # 注意:ssh访问自己也需要输入密码,所以我们需要将公钥也拷贝给102 
  8.  [kocdaniel@hadoop102 .ssh]$ ssh-copy-id hadoop102 
  9.   
  10.  ``` 
  • 同样,在配置resourcemanager的主机hadoop103上执行同样的操作,然后就可以群起集群了

群起集群

(编辑:ASP站长网)

网友评论
推荐文章
    热点阅读