从0开始用docker搭建 hadoop分布式环境

* 以下命令均是在centos7使用root用户操作
  1. 在centos7中安装docker :

yum install -y docker

  1. 启动docker服务:

service docker start

  1. 从阿里云的仓库拉取一个具有jdk和hadoop环境的一个基础镜像,当然也可以自己一步一步配置 ,在这里我就直接拉取一个基础镜像来使用

docker pull registry.cn-hangzhou.aliyuncs.com/kaibb/hadoop

  1. 拉取成功后,利用docker image 可以看到拉取的基础镜像已经在电脑里面了
    镜像.png
  2. 接下来通过docker镜像启动三个容器 ,分别为hadoop0,hadoop1和hadoop2

docker run -it --name hadoop0 -h hadoop0 [拉取的镜像名称] /bin/bash

  • -i: 以交互模式运行容器,通常与 -t 同时使用;
  • -t: 为容器重新分配一个伪输入终端,通常与 -i 同时使用;
  • --name: 为容器指定一个名称;
  • -h:指定容器的主机名;
    启动容器.png
  1. 现在我么你已经启动了一个docker容器 ;重复上面操作创建hadoop1和hadoop2
    然后在这个容器里面已经安装好了jdk和hadoop ,我们可以利用hadoop version和java -version 查看。


    hadoop版本.png
    jdk版本.png
  2. 经过上面的操作后,我们可以使用 ctrl +d 退出容器,回到centos7虚拟机中 ,使用

docker exec -it 【容器名】/bin/bash

可以启动容器

  • docker attach 【容器名】也可以启动容器,但是当我们ctrl+d退出容器后。容器就会自动关闭,下次还要用docker start 【容器名】启动容器,所以我们选择上面那条命令启动,然后用docker ps 命令来查看我们当前运行的容器

docker ps

![当前容器.png]@$N@)K~@SMZCN.png

  1. 经过以上操作后我们的集群基本环境就好了,接下来我们来配置单个容器hadoop环境
    ①: 先配置SSH,配置无密的SSH

/etc/init.d/ssh start

启动sshd服务
生成密钥


密钥.png

现在我们生成的密钥存放在/root/.ssh/id_rsa.pub 中


密钥.png
  1. 将密钥写入 /root/.ssh/authorized_keys 中

cat /root/.ssh/id_rsa.pub > /root/.ssh/authorized_keys

写入密钥.png
  1. 写入成功后,使用 ssh localhost 可以登上本机,代表设置成功
    设置成功.png
  2. 将三台机器的密钥全都写入hadoop0的 /root/.ssh/authorized_keys中 ,

    如下图所示:
    写入三台机器的密钥.png
  3. 配置hadoop0的ip与主机名的映射表
    首先查看本容器ip地址:

ip addr

查看ip.png

分别获取到三台机器的IP ,写入下列文件

vim /etc/hosts

主机名与ip的映射表.png

保存退出后
如果使用ssh hadoop1 命令能够直接登陆到hadoop1 ,说明以上操作成功,那么我们继续下面操作


配置成功.png
  1. 现在我们来配置hadoop运行环境,刚才我们从阿里云仓库拉取的镜像jdk和hadoop均是放在/opt/tools/文件夹下的 ,然后我们进入到/opt/tools/hadoop/etc/hadoop目录下;
    我们需要配置下面几个文件
    ①:hadoop-env.sh:修改有关java的环境
    修改第25行的java环境

export JAVA_HOME=/opt/tools/jdk1.8.0_77

②:配置core-site.xml

<configuration>
  <property>
    <name>fs.defaultFS</name>
    <value>hdfs://hadoop0:9000</value>
  </property>
<property>
  <name>hadoop.tmp.dir</name>
  <value>/hadoop/tmp</value>
</property>
<property>
    <name>fs.trash.interval</name>
    <value>1440</value>
  </property>
</configuration>

fs.defaultFS:表示集群namenode的地址
hadoop.tmp.dir:表示临时文件路径
fs.trash.interval:表示回收站的保留时间(分钟),也即hdfs的文件删除后,在回收站里面保留的时长
③:配置hdfs-site.xml

<configuration>
  <property>
    <name>dfs.replication</name>
    <value>1</value>
  </property>
  <property>
    <name>dfs.datanode.data.dir</name>
    <value>/hadoop/data</value>
  </property>
  <property>
    <name>dfs.namenode.name.dir</name>
    <value>/hadoop/name</value>
  </property>
 <property>
    <name>dfs.namenode.checkpoint.dir</name>
    <value>/home/ahadoop/hadoop-data/checkpoint</value>
  </property>
<property>
    <name>dfs.blocksize</name>
    <value>134217728</value>
  </property>
</configuration>

dfs.replication:表示hdfs的数据块备份数量,默认是3
dfs.datanode.data.dir :表示datanode的数据路径
dfs.namenode.name.dir:表示namenode的数据路径
dfs.namenode.checkpoint.dir:表示checkpoint的数据路径
dfs.blocksize:表示数据块的大小,此处设置为128M
④:配置mapred-site.xml

<configuration>
  <property>
    <name>mapreduce.framework.name</name>
    <value>yarn</value>
  </property>
</configuration>

mapreduce.framework.name:表示使用的yarn框架
⑤:配置yarn-site.xml

<configuration>
 <property>
<name>yarn.resourcemanager.address</name>
 <value>Master:8032</value>
</property>
<property>
    <name>yarn.resourcemanager.scheduler.address</name>
    <value>hadoop0:8030</value> </property> <property>
    <name>yarn.resourcemanager.resource-tracker.address</name>
    <value>hadoop0:8031</value>
</property>
<property>
<name>yarn.resourcemanager.admin.address</name>
<value>hadoop0:8033</value>
</property>
<property>
    <name>yarn.resourcemanager.webapp.address</name>
    <value>hadoop0:8088</value>
</property>
 <property>
    <name>yarn.nodemanager.aux-services</name>
    <value>mapreduce_shuffle</value>
</property>
 <property>
 <name>yarn.nodemanager.aux-services.mapreduce.shuffle.class</name>
 <value>org.apache.hadoop.mapred.ShuffleHandler</value>
</property>
</configuration>
  • yarn.resourcemanager.address : 表示resourcemanager的地址
  • yarn.resourcemanager.webapp.address : 表示resourcemanager的网页访问地址和端口;
  • yarn.nodemanager.aux-services:NodeManager上运行的附属服务,需配置成mapreduce_shuffle,才可运行MapReduce程序,否则会报错;
    ⑥:修改hadoop0中hadoop的一个配置文件etc/hadoop/slaves
    删除原来的所有内容,修改为如下


    配置节点.png
  1. 做完上述操作后
    我们通过scp命令将所有配置全部发送到其他容器
scp -rq /opt/tools/hadoop/ hadoop1:/opt/tools/hadoop/
scp /etc/hosts hadoop1:/etc/hosts
scp /root/.ssh/authorized_keys hadoop1:/root/.ssh/authorized_keys

![]SQ7TSJACFC@LYOO(NR]]_I.png](http://upload-images.jianshu.io/upload_images/6071674-ee56bb6751d68ae5.png?imageMogr2/auto-orient/strip%7CimageView2/2/w/1240)
到这里为止,所有的配置工作都做好了。

然后格式化namenode

hadoop namenode -format
没有报错则代表刚才的配置成功了,有报错的话需要根据报错查找问题

格式化成功.png

接着启动集群

cd /opt/tools/hadoop/sbin/

./start-all.sh

分布式集群就启动了

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,922评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,591评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 160,546评论 0 350
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,467评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,553评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,580评论 1 293
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,588评论 3 414
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,334评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,780评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,092评论 2 330
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,270评论 1 344
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,925评论 5 338
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,573评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,194评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,437评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,154评论 2 366
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,127评论 2 352

推荐阅读更多精彩内容