在Ubuntu上部署HDFS(Hadoop分布式文件系统)服务涉及多个步骤,包括安装Java、配置Hadoop环境、设置HDFS集群等。以下是一个基本的指南:
Hadoop需要Java运行时环境。你可以使用OpenJDK或Oracle JDK。
sudo apt update
sudo apt install openjdk-11-jdk
验证安装:
java -version
从Apache Hadoop官方网站下载最新版本的Hadoop,并解压到指定目录。
wget https://downloads.apache.org/hadoop/common/hadoop-3.3.4/hadoop-3.3.4.tar.gz
tar -xzvf hadoop-3.3.4.tar.gz -C /usr/local/
重命名解压后的目录(可选):
sudo mv /usr/local/hadoop-3.3.4 /usr/local/hadoop
编辑~/.bashrc或/etc/profile文件,添加以下内容:
export JAVA_HOME=/usr/lib/jvm/java-11-openjdk-amd64
export HADOOP_HOME=/usr/local/hadoop
export PATH=$PATH:$HADOOP_HOME/bin:$HADOOP_HOME/sbin
使配置生效:
source ~/.bashrc
编辑Hadoop配置文件,主要涉及core-site.xml、hdfs-site.xml和yarn-site.xml。
在$HADOOP_HOME/etc/hadoop/core-site.xml中添加:
<configuration>
<property>
<name>fs.defaultFS</name>
<value>hdfs://localhost:9000</value>
</property>
</configuration>
在$HADOOP_HOME/etc/hadoop/hdfs-site.xml中添加:
<configuration>
<property>
<name>dfs.replication</name>
<value>1</value>
</property>
<property>
<name>dfs.namenode.name.dir</name>
<value>/usr/local/hadoop/data/namenode</value>
</property>
<property>
<name>dfs.datanode.data.dir</name>
<value>/usr/local/hadoop/data/datanode</value>
</property>
</configuration>
创建数据目录:
sudo mkdir -p /usr/local/hadoop/data/namenode
sudo mkdir -p /usr/local/hadoop/data/datanode
修改权限:
sudo chown -R $USER:$USER /usr/local/hadoop/data
在$HADOOP_HOME/etc/hadoop/yarn-site.xml中添加:
<configuration>
<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>
在第一次启动HDFS之前,需要对NameNode进行格式化。
hdfs namenode -format
启动HDFS集群:
start-dfs.sh
启动YARN(可选):
start-yarn.sh
检查HDFS状态:
jps
你应该看到NameNode、SecondaryNameNode、DataNode和ResourceManager进程。
访问Web界面验证:
http://localhost:50070http://localhost:8088停止HDFS集群:
stop-dfs.sh
停止YARN(可选):
stop-yarn.sh
通过以上步骤,你应该能够在Ubuntu上成功部署HDFS服务。