在浏览器中无法看到在docker容器中运行的Hadoop UI

时间:2019-03-31 11:49:46

标签: docker hadoop weave

我在三个不同主机上有一个由三个容器组成的Hadoop集群;详细信息如下:   首先,我通过以下命令在三台主机(150.20.11.133,150.20.11.136,150.20.11.157)中安装“编织网”:

 sudo curl -L git.io/weave -o /usr/local/bin/weave
 sudo chmod a+x /usr/local/bin/weave
 eval $(weave env)

然后,我通过编织将三台主机连接在一起。实际上,我在三个主机中运行了此命令:

例如在150.20.11.133中:

 Weave launch 150.20.11.136 150.20.11.157

将三台主机连接在一起后,我必须在主服务器和工作服务器之间设置 SSH 无密码。因此,我做了以下工作: 在每个主机中:

 ssh-keygen -t rsa

在母版中:

 ssh-copy-id spark@172.28.10.136
 ssh-copy-id spark@172.28.10.157
 cat /home/user/.ssh/id_rsa.pub >> /home/user/.ssh/authorized_keys

因此,我可以在没有密码的情况下从主机主机运行 SSH

在每个主机中,我都构建了具有hadoop配置的Docker文件,然后运行该文件:

在大师中:

 docker run -v /home/user/.ssh:/root/.ssh --privileged -p 52222:22 
 -e WEAVE_CIDR=10.32.0.1/12 -ti my-hadoop

在slave1中:

 docker run -v /home/user/.ssh:/root/.ssh --privileged -p 52222:22 
 -e WEAVE_CIDR=10.32.0.2/12 -ti my-hadoop

在slave2中:

 docker run -v /home/user/.ssh:/root/.ssh --privileged -p 52222:22 
 -e WEAVE_CIDR=10.32.0.3/12 -ti my-hadoop

在每个容器中,我运行了以下命令:

 chmod 700 ~/.ssh/
 chmod 600 ~/.ssh/*
 chown -R root ~/.ssh/
 chgrp -R root ~/.ssh/
 chmod -R 750 /root/.ssh/authorized_keys

在主容器中,我运行了此命令以运行 SSH localhost

 ssh-keygen -f "/root/.ssh/known_hosts" -R localhost

此外,我在每个容器节点中启动了 SSH 服务:

 service ssh restart

因此,我可以在没有密码的情况下从主容器向从属服务器运行 SSH 。 对于hadoop配置,我做了以下工作: 首先进入主节点:

  hadoop namenode -format

工人在三个容器中具有以下内容:

  root@10.32.0.2
  root@10.32.0.3

core-site.xml 在三个容器中包含以下内容:

  <configuration>
    <property>
       <name>fs.defaultFS</name>
       <value>hdfs://root@10.32.0.1:9000</value>
    </property>
  </configuration>

hdfs-site.xml 在三个容器中也具有这些内容:

   <configuration>
    <property>
       <name>dfs.replication</name>
       <value>1</value>
    </property>
    <property>
       <name>dfs.namenode.name.dir</name>
       <value>file:/usr/local/hadoop_store/hdfs/namenode</value>
    </property>
    <property>
       <name>dfs.datanode.data.dir</name>
       <value>file:/usr/local/hadoop_store/hdfs/datanode</value>
    </property>
   </configuration>

然后我在主容器中运行了这个

   /opt/hadoop/sbin/start-dfs.sh

在每个容器中运行 jps 时,我收到以下结果: 在主容器中:

   483 SecondaryNameNode
   231 NameNode
   747 Jps

在每个工人中:

   117 DataNode
   186 Jps

问题是,我想在浏览器中看到Hadoop UI。我运行此URL,但未显示任何内容:

    http://10.32.0.1:8088

顺便说一句,我已经在docker文件中公开了这些端口:

    EXPOSE 22 9000 8088 50070 50075 50030 50060

请告诉我如何在浏览器中看到Hadoop集群UI?

任何帮助将不胜感激。

2 个答案:

答案 0 :(得分:1)

似乎您不是通过/opt/hadoop/sbin/start-yarn.sh启动YARN

端口8088用于YARN Web UI,而端口50070用于查看HDFS状态。

答案 1 :(得分:0)

通过在 hdfs-site.xml 中添加这些行,我可以在浏览器中看到数据节点。

<property>
     <name>dfs.http.address</name>
     <value>10.32.0.1:50070</value>
</property>

<property>
     <name>dfs.secondary.http.address</name>
     <value>10.32.0.1:50090</value>
</property>

希望这很有帮助。