腾讯云centos服务器上安装hadoop踩坑记
- 首先需要下载hadoop、jdk1.8
在本地下载好jdk1.8
https://www.oracle.com/java/technologies/javase/javase-jdk8-downloads.html
hadoop的安装包:
链接:https://pan.baidu.com/s/1LkTMeLl0qRsuvSZJAUpzUA
提取码:tkmr
- 通过xftp上传的服务器,我上传的位置分别是:
java路径
/usr/java
hadoop路径
/usr/local
- 解压配置环境变量
解压Java
cd /usr/java
tar zxvf jdk-8u251-linux-x64.tar.gz
解压hadoop
cd /usr/local
tar zxvf hadoop-2.8.5.tar.gz
- 配置环境变量
vi /etc/profile
export JAVA_HOME=/usr/java/jdk1.8.0_251
export PATH=$JAVA_HOME/bin:$PATH
export CLASSPATH=.:$JAVA_HOME/lib/dt.jar:$JAVA_HOME/lib
export HADOOP_HOME=/usr/local/hadoop-2.8.5
export PATH=$PATH:$HADOOP_HOME/bin
- 使之生效
source /etc/profile
- 修改/usr/hadoop/hadoop2.7.3/etc/hadoop/core-site.xml 文件
<configuration>
<!-- 指定HDFS老大(namenode)的通信地址 -->
<property>
<name>fs.defaultFS</name>
<value>hdfs://localhost:9000</value>
</property>
<!-- 指定hadoop运行时产生文件的存储路径 -->
<property>
<name>hadoop.tmp.dir</name>
<value>/usr/hadoop/tmp</value>
</property>
</configuration>
fs.defaultFS直接用localhost就行,如果重命名了主机名,也可以用重命名的。
- 修改/usr/hadoop/hadoop2.7.3/etc/hadoop/hdfs-site.xml
<configuration>
<property>
<name>dfs.name.dir</name>
<value>/usr/hadoop/hdfs/name</value>
<description>namenode上存储hdfs名字空间元数据 </description>
</property>
<property>
<name>dfs.data.dir</name>
<value>/usr/hadoop/hdfs/data</value>
<description>datanode上数据块的物理存储位置</description>
</property>
<!-- 设置hdfs副本数量 -->
<property>
<name>dfs.replication</name>
<value>1</value>
</property>
<property>
<name>dfs.namenode.http.address</name>
<value>slave1:50070</value>
</property>
</configuration>
- SSH免密码登录
ssh-keygen -t dsa -P '' -f ~/.ssh/id_dsa
cat ~/.ssh/id_dsa.pub >> ~/.ssh/authorized_keys
chmod 0600 ~/.ssh/authorized_keys
- hdfs启动与停止
第一次启动hdfs需要格式化,之后启动就不需要的:
cd /usr/local/hadoop-2.8.5
./bin/hdfs namenode -format
- 启动命令和关闭命令
./sbin/start-dfs.sh # 启动命令
./sbin/stop-dfs.sh # 停止命令
这一步可能会出问题解决方案是:
cd /usr/local/hadoop-2.8.5/etc/hadoop
vi hadoop-env.sh
将如下位置修改为JAVA_HOME的路径
- 结果
- 从图中看,会启动namenode,datanode,secondarynamenode浏览器输入:http://129.211.85.92:50070/ 查看效果:
这一步可能会出问题参考方案:
https://blog.csdn.net/xingyue0422/article/details/85316822(我已经之前做了)
https://blog.csdn.net/wy7980/article/details/40710631?utm_source=blogxgwz5?utm_medium=distribute.pc_relevant.none-task-blog-baidujs-2
- 接下来配置yarn文件. 配置/usr/hadoop/hadoop-2.7.3/etc/hadoop/mapred-site.xml 。这里注意一下,hadoop里面默认是mapred-site.xml.template 文件,如果配置yarn,把mapred-site.xml.template 重命名为mapred-site.xml 。如果不启动yarn,把重命名还原。
cd /usr/local/hadoop-2.8.5/etc/hadoop
mv mapred-site.xml.template mapred-site.xml
- vi mapred-site.xml
<configuration>
<!-- 通知框架MR使用YARN -->
<property>
<name>mapreduce.framework.name</name>
<value>yarn</value>
</property>
</configuration>
- vi yarn-site.xml
<configuration>
<!-- reducer取数据的方式是mapreduce_shuffle -->
<property>
<name>yarn.nodemanager.aux-services</name>
<value>mapreduce_shuffle</value>
</property>
</configuration>
- 启动yarn
启动:
cd /usr/local/hadoop-2.8.5
./sbin/start-yarn.sh
停止:
./sbin/stop-yarn.sh
如图:
会启动resourcemanager,nodemanager
可以用jps命令查看启动了什么进程:
浏览器输入:http://129.211.85.92:8088 (8088是默认端口,如果端口占用,先把占用的端口杀掉 netstat -ano)
这样,dfs和yarn就启动成功了。