2024年大数据最全华为云云耀云服务器L实例评测|在Docker环境下部署Hadoop(2)

启动Docker服务
systemctl enable docker
systemctl start docker
systemctl status docker

三、创建hadoop容器

宿主机环境准备
拉取镜像

docker pull centos:7

进入存放安装包目录

cd /mnt/docker_share

上传jdk和hadoop
  • 前提:安装上传软件工具(yum install lrzsz)

rz jdk*.tar.gz;rz hadoop*.tar.gz

解压软件包
  • 解压到opt目录,后续我们将映射该目录下的软件包到docker容器
tar -xvzf jdk-8u141-linux-x64.tar.gz -C /opt
tar -xvzf hadoop-2.7.0.tar.gz -C /opt

创建用于保存数据的文件夹
mkdir -p /data/dfs/nn
mkdir -p /data/dfs/dn

image-20230918193712822

容器环境准备
启动hadoop容器
  • 注意一定要添加 --privileged=true,否则无法使用系统服务
docker run \
--net docker-bd0 --ip 172.33.0.121 \
-p 50070:50070 -p 8088:8088 -p 19888:19888 \
-v /mnt/docker_share:/mnt/docker_share \
-v /etc/hosts:/etc/hosts \
-v /opt/hadoop-2.7.0:/opt/hadoop-2.7.0 \
-v /opt/jdk1.8.0_141:/opt/jdk1.8.0_141 \
-v /data/dfs:/data/dfs \
--privileged=true \
-d  -it --name hadoop centos:7 \
/usr/sbin/init

注意:确保在主机上禁用SELinux

进入hadoop容器
docker exec -it hadoop bash

image-20230918193838301

安装vim
  • 为了后续方便编辑配置文件,安装一个vim

yum install -y vim

安装ssh
  • 因为启动Hadoop集群需要进行免密登录,Centos7容器需要安装ssh
yum install -y openssl openssh-server
yum install -y openssh-client*

  • 修改ssh配置文件
vim /etc/ssh/sshd_config
# 在文件最后添加
PermitRootLogin yes
RSAAuthentication yes
PubkeyAuthentication yes

  • 启动ssh服务
systemctl start sshd.service
# 设置开机自动启动ssh服务
systemctl enable sshd.service
# 查看服务状态
systemctl status sshd.service

配置免密登录
生成秘钥

ssh-keygen

设置密码
  • 设置root用户的密码为123456

passwd

拷贝公钥

ssh-copy-id hadoop.bigdata.cn

测试免密登录

ssh hadoop.bigdata.cn

配置JDK
vim /etc/profile
# 配置jdk的环境变量
export JAVA\_HOME=/opt/jdk1.8.0_141
export CLASSPATH=${JAVA\_HOME}/lib
export PATH=${JAVA\_HOME}/bin:$PATH
# 让上一步配置生效
source /etc/profile

image-20230918193916756

配置Hadoop
  • core-site.xml
  <property>
    <name>fs.defaultFS</name>
    <value>hdfs://hadoop.bigdata.cn:9000</value>
  </property>
  <property>
    <name>hadoop.proxyuser.root.hosts</name>
    <value>*</value>
  </property>
  <property>
    <name>hadoop.proxyuser.root.groups</name>
    <value>*</value>
  </property>
  <property>
    <name>hadoop.http.staticuser.user</name>
    <value>root</value>
  </property>

  • hdfs-site.xml
  <property>
    <name>dfs.namenode.http-address</name>
    <value>hadoop.bigdata.cn:50070</value>
  </property>
  <property>
    <name>dfs.namenode.secondary.http-address</name>
    <value>hadoop.bigdata.cn:50090</value>
  </property>
  <property>
    <name>dfs.replication</name>
    <value>1</value>
  </property>
  <property>
    <name>dfs.namenode.name.dir</name>
    <value>file:///data/dfs/nn</value>
  </property>
  <property>
    <name>dfs.datanode.data.dir</name>
    <value>file:///data/dfs/dn</value>
  </property>
  <property>
    <name>dfs.permissions</name>
    <value>false</value>
  </property>

  • yarn-site.xml
  <property>
    <name>yarn.resourcemanager.hostname</name>
    <value>hadoop-yarn</value>
  </property>
  <property>
    <name>yarn.nodemanager.aux-services</name>
    <value>mapreduce_shuffle</value>
  </property>
  <property>
    <name>yarn.resourcemanager.hostname</name>
    <value>hadoop.bigdata.cn</value>
  </property>
  <property>
    <name>yarn.log-aggregation-enable</name>
    <value>true</value>
  </property>
  <property>
    <name>yarn.nodemanager.remote-app-log-dir</name>
    <value>/user/container/logs</value>
  </property>

  • mapred-site.xml
  <property>
    <name>mapreduce.framework.name</name>
    <value>yarn</value>
  </property>
  <property>
    <name>mapreduce.jobhistory.address</name>
    <value>hadoop.bigdata.cn:10020</value>
  </property>
  <property>
    <name>mapreduce.jobhistory.webapp.address</name>
    <value>hadoop.bigdata.cn:19888</value>
  </property>
  <property>
    <name>mapreduce.jobhistory.intermediate-done-dir</name>
    <value>/tmp/mr-history</value>
  </property>
  <property>
    <name>mapreduce.jobhistory.done-dir</name>
    <value>/tmp/mr-done</value>
  </property>

  • hadoop-env.sh
export JAVA\_HOME=/opt/jdk1.8.0_141

  • slaves
hadoop.bigdata.cn

  • 配置环境变量

    • vim /etc/profile
    • source /etc/profile
export HADOOP\_HOME=/opt/hadoop-2.7.0
export PATH=${HADOOP\_HOME}/sbin:${HADOOP\_HOME}/bin:$PATH

四、初始化并启动Hadoop

格式化hdfs

hdfs namenode -format

启动hadoop
start-all.sh 
# 启动history server
mr-jobhistory-daemon.sh start historyserver

image-20230918194219493

测试hadoop
cd $HADOOP\_HOME
bin/hadoop jar share/hadoop/mapreduce/hadoop-mapreduce-examples-2.7.0.jar pi 2 1

image-20230918194247221
查看进程
bash-4.1# jps
561 ResourceManager
659 NodeManager
2019 Jps
1559 NameNode
1752 SecondaryNameNode
249 DataNode

image-20230918194306053

五、配置开启容器启动Hadoop

创建启动脚本
  • 创建新文件存放启动脚本
touch /etc/bootstrap.sh
chmod a+x /etc/bootstrap.sh
vim /etc/bootstrap.sh

  • 文件内容
#!/bin/bash
source /etc/profile
cd /opt/hadoop-2.7.0
start-dfs.sh
start-yarn.sh
mr-jobhistory-daemon.sh start historyserver

img
img

网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。

需要这份系统化资料的朋友,可以戳这里获取

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!

opt/hadoop-2.7.0
start-dfs.sh
start-yarn.sh
mr-jobhistory-daemon.sh start historyserver




[外链图片转存中...(img-8uubqP00-1714647910984)]
[外链图片转存中...(img-qC2gZwYg-1714647910985)]

**网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。**

**[需要这份系统化资料的朋友,可以戳这里获取](https://bbs.csdn.net/topics/618545628)**


**一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!**

  • 9
    点赞
  • 19
    收藏
    觉得还不错? 一键收藏
  • 6
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值