在Docker中跑Hadoop与镜像制作
程序员文章站
2022-03-07 16:17:31
重复造*,这里使用重新打包生成一个基于Docker的Hadoop镜像; Hadoop集群依赖的软件分别为:jdk、ssh等,所以只要这两项还有Hadoop相关打包进镜像中去即可; 配置文件准备 1、Hadoop相关配置文件:core site.xml ......
重复造*,这里使用重新打包生成一个基于docker的hadoop镜像;
hadoop集群依赖的软件分别为:jdk、ssh等,所以只要这两项还有hadoop相关打包进镜像中去即可;
配置文件准备
1、hadoop相关配置文件:core-site.xml、hdfs-site.xml、mapred-site.xml、yarn-site.xml、slaves、hadoop-env.sh
2、ssh配置文件:ssh_config
3、hadoop集群启动文件:start-hadoop.sh
制作镜像
1、安装依赖
run apt-get update && \ apt-get install -y openssh-server openjdk-8-jdk wget
2、下载hadoop包
run wget http://mirror.bit.edu.cn/apache/hadoop/common/hadoop-2.10.0/hadoop-2.10.0.tar.gz && \ tar -xzvf hadoop-2.10.0.tar.gz && \ mv hadoop-2.10.0 /usr/local/hadoop && \ rm hadoop-2.10.0.tar.gz && \ rm /usr/local/hadoop/share/doc -rf
3、配置环境变量
env java_home=/usr/lib/jvm/java-8-openjdk-amd64 env hadoop_home=/usr/local/hadoop env path=$path:/usr/local/hadoop/bin:/usr/local/hadoop/sbin
4、生成ssh key,用于节点免密登录
run ssh-keygen -t rsa -f ~/.ssh/id_rsa -p '' && \ cat ~/.ssh/id_rsa.pub >> ~/.ssh/authorized_keys
5、创建hadoop相关目录、复制相关配置文件、相关文件添加执行权限,最后格式化namenode节点,各个节点启动时,启动ssh服务;
run mkdir -p ~/hdfs/namenode && \ mkdir -p ~/hdfs/datanode && \ mkdir $hadoop_home/logs copy config/* /tmp/ #复制ssh、hadoop配置相关 run mv /tmp/ssh_config ~/.ssh/config && \ mv /tmp/hadoop-env.sh /usr/local/hadoop/etc/hadoop/hadoop-env.sh && \ mv /tmp/hdfs-site.xml $hadoop_home/etc/hadoop/hdfs-site.xml && \ mv /tmp/core-site.xml $hadoop_home/etc/hadoop/core-site.xml && \ mv /tmp/mapred-site.xml $hadoop_home/etc/hadoop/mapred-site.xml && \ mv /tmp/yarn-site.xml $hadoop_home/etc/hadoop/yarn-site.xml && \ mv /tmp/slaves $hadoop_home/etc/hadoop/slaves && \ mv /tmp/start-hadoop.sh ~/start-hadoop.sh && \ mv /tmp/run-wordcount.sh ~/run-wordcount.sh #添加执行权限 run chmod +x ~/start-hadoop.sh && \ chmod +x ~/run-wordcount.sh && \ chmod +x $hadoop_home/sbin/start-dfs.sh && \ chmod +x $hadoop_home/sbin/start-yarn.sh # format namenode run /usr/local/hadoop/bin/hdfs namenode -format
在docker中跑hadoop集群
通过上面的dockerfile生成了镜像后,这里即可使用上面所生成的镜像搭建hadoop集群;这里启动一个master、两个slave节点;
添加桥接网络:
docker network create --driver=bridge solinx-hadoop
启动master节点:
docker run -itd --net=solinx-hadoop -p 10070:50070 -p 8088:8088 --name solinx-hadoop-master --hostname solinx-hadoop-master solinx/hadoop:0.1
启动slave1节点:
docker run -itd --net=solinx-hadoop --name solinx-hadoop-slave1 --hostname solinx-hadoop-slave1 solinx/hadoop:0.1
启动slave2节点:
docker run -itd --net=solinx-hadoop --name solinx-hadoop-slave2 --hostname solinx-hadoop-slave1 solinx/hadoop:0.1
进入master节点,执行启动hadoop集群脚本即可:
上一篇: XPosed基本使用 Activity生命周期拦截
下一篇: php怎么计算一个月有几周