在centos系统上搭建hdfs(hadoop分布式文件系统)集群需要经过多个步骤,包括安装java环境、设置hadoop环境、配置ssh无密码登录以及配置hdfs本身。以下是一个详细的指南:
1. 安装Java
Hadoop依赖于Java运行环境。你可以通过以下命令来安装OpenJDK:
sudo yum install java-1.8.0-openjdk-devel
安装完成后,验证Java版本:
java -version
2. 下载并解压Hadoop
从Apache Hadoop的官方网站下载最新版本的Hadoop,并将其解压到指定目录。例如:
wget https://www.apache.org/dyn/closer.cgi/hadoop/common/hadoop-3.3.4/hadoop-3.3.4.tar.gz tar -xzvf hadoop-3.3.4.tar.gz -C /usr/local/
3. 设置Hadoop环境变量
编辑/etc/profile.d/hadoop.sh文件,加入以下内容:
export HADOOP_HOME=/usr/local/hadoop-3.3.4 export PATH=$PATH:$HADOOP_HOME/bin:$HADOOP_HOME/sbin
使环境变量生效:
source /etc/profile.d/hadoop.sh
4. 配置SSH无密码登录
在每个节点上生成SSH密钥对,并将公钥复制到其他节点:
ssh-keygen -t rsa ssh-copy-id hadoop@node2 ssh-copy-id hadoop@node3
5. 配置HDFS
编辑$HADOOP_HOME/etc/hadoop/core-site.xml文件,添加以下配置:
fs.defaultFS hdfs://namenode:9000
编辑$HADOOP_HOME/etc/hadoop/hdfs-site.xml文件,添加以下配置:
dfs.replication 3 dfs.namenode.name.dir /usr/local/hadoop-3.3.4/data/namenode dfs.datanode.data.dir /usr/local/hadoop-3.3.4/data/datanode
6. 格式化NameNode
在NameNode节点上运行以下命令:
hdfs namenode -format
7. 启动HDFS集群
在NameNode节点上启动HDFS:
start-dfs.sh
在DataNode节点上同样启动DataNode:
start-dfs.sh
8. 检查集群状态
通过访问NameNode的Web界面(通常是http://namenode:50070),可以查看集群的状态。
9. 配置YARN(可选)
如果你需要运行YARN,可以按照类似步骤进行配置。
配置YARN的core-site.xml:
yarn.resourcemanager.hostname resourcemanager
配置YARN的yarn-site.xml:
yarn.nodemanager.aux-services mapreduce_shuffle yarn.nodemanager.aux-services.mapreduce.shuffle.class org.apache.hadoop.mapred.ShuffleHandler
启动YARN:
在ResourceManager节点上启动ResourceManager:
start-yarn.sh
在NodeManager节点上启动NodeManager:
start-yarn.sh
10. 检查YARN集群状态
访问ResourceManager的Web界面(通常是http://resourcemanager:8088),查看YARN集群状态。
通过以上步骤,你应该能够在CentOS上成功搭建一个基本的HDFS集群。根据具体需求,可能还需要进行进一步的配置和优化。










