配置CentOS上的Hadoop分布式文件系统(HDFS)以提升性能涉及多个步骤,包括安装和配置Hadoop、调整系统参数、优化网络设置等。以下是一个详细的配置指南:
首先,确保系统上安装了合适的JDK版本。可以通过以下命令安装OpenJDK:
sudo yum update -y
sudo yum install java-1.8.0-openjdk-devel -y
验证Java安装:
java -version
从Apache Hadoop官方网站下载最新版本的Hadoop,并将其解压到指定目录,例如 /usr/local/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
编辑 /etc/profile.d/hadoop.sh 文件,添加以下内容:
export JAVA_HOME=/usr/lib/jvm/java-1.8.0-openjdk
export HADOOP_HOME=/usr/local/hadoop
export PATH=$PATH:$HADOOP_HOME/bin:$HADOOP_HOME/sbin
使环境变量生效:
source /etc/profile.d/hadoop.sh
core-site.xml编辑 $HADOOP_HOME/etc/hadoop/core-site.xml 文件,添加以下内容:
<configuration>
<property>
<name>fs.defaultFS</name>
<value>hdfs://namenode:9000</value>
</property>
</configuration>
hdfs-site.xml编辑 $HADOOP_HOME/etc/hadoop/hdfs-site.xml 文件,添加以下内容:
<configuration>
<property>
<name>dfs.replication</name>
<value>3</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>
<property>
<name>dfs.blocksize</name>
<value>128m</value>
</property>
</configuration>
yarn-site.xml 和 mapred-site.xml根据需要配置 yarn-site.xml 和 mapred-site.xml 文件,例如:
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>
mapred-site.xml:
<configuration>
<property>
<name>mapreduce.framework.name</name>
<value>yarn</value>
</property>
</configuration>
在首次启动HDFS之前,需要格式化NameNode:
hdfs namenode -format
启动HDFS的NameNode和DataNode服务:
start-dfs.sh
打开浏览器,访问 http://<your_namenode_ip>:50070,你应该能看到HDFS的Web界面。
调整系统内核参数以提升性能,例如:
echo "net.ipv4.tcp_fin_timeout = 30" >> /etc/sysctl.conf
echo "net.ipv4.tcp_tw_reuse = 1" >> /etc/sysctl.conf
echo "net.ipv4.tcp_tw_recycle = 1" >> /etc/sysctl.conf
echo "net.ipv4.tcp_keepalive_time = 1200" >> /etc/sysctl.conf
echo "net.core.somaxconn = 32768" >> /etc/sysctl.conf
echo "net.core.rmem_max = 67108864" >> /etc/sysctl.conf
echo "net.core.wmem_max = 67108864" >> /etc/sysctl.conf
echo "net.ipv4.tcp_rmem = 4096 87380 67108864" >> /etc/sysctl.conf
echo "net.ipv4.tcp_wmem = 4096 65536 67108864" >> /etc/sysctl.conf
sysctl -p
确保足够的网络带宽,并优化网络参数,例如:
net.ipv4.tcp_max_syn_backlog = 8192
net.ipv4.tcp_max_tw_buckets = 5000
net.ipv4.tcp_syncookies = 1
使用监控工具如Ganglia、Prometheus等监控集群性能,并根据需要进行调整。
通过以上步骤,你可以有效地提升CentOS上HDFS的性能。根据具体的使用场景和需求,可能需要调整不同的参数和配置。