命令 hadoop dfsadmin -safemode get 查看安全模式状态
命令 hadoop dfsadmin -safemode enter 进入安全模式状态
命令 hadoop dfsadmin -safemode leave 离开安全模式
vim /etc/profile 配置全局jdk、hadoop的环境变量
export JAVA_HOME=/opt/jdk
export CLASSPATH=$JAVA_HOME/lib/
export PATH=$PATH:$JAVA_HOME/bin/
export HADOOP_HOME=/opt/hadoop
export PATH=$PATH:$HADOOP_HOME/sbin:$HADOOP_HOME/bin
创建ssh的key密钥(三台都要)
ssh-keygen -t rsa
相互传输ssh的key
分别将key传给自己和另两台主机:
三台主机都分开运行以下三条命令
命令:
cd .ssh
ssh-copy-id master
ssh-copy-id slave0
ssh-copy-id slave00
测试免密登录:ssh+机名
ssh localhost 测试密码登录
设置免密登录执行一下三条命令
ssh-keygen -t dsa -P ‘’ -f ~/.ssh/id_dsa
cat ~/.ssh/id_dsa.pub >> ~/.ssh/authorized_keys
chmod 0600 ~/.ssh/authorized_keys
ssh localhost 再次登录(免密)
<configuration>
<property>
<name>fs.defaultFSname>
<value>hdfs://localhost:9000value>
property>
<property>
<name>hadoop.tem.dirname>
<value>/opt/hadoop/tmpvalue>
property>
configuration>
<configuration>
<property>
<name>dfs.replicationname>
<value>1value>
property>
<property>
<name>dfs.namenode.name.dirname>
<value>file:///opt/hadoop/data/namenodevalue>
property>
<property>
<name>dfs.datanode.data.dirname>
<value>file:///opt/hadoop/data/datanodevalue>
property>
configuration>
export JAVA_HOME=/opt/jdk
hdfs namenode -format 格式化
参考上面伪分布配置jdk
(hostname文件添加本机机名 hosts文件删除原有再添加三台机子的IP+机名)
参考上面伪分布配置免密登录
在主机上测试是否能连接上其他两台主机
ssh +主机名(免密)
在hadoop-env.sh文件mapred-env.sh文件yarn-env.sh中修改或添加jdk的路径(yarn-env.sh要添加不修改)
<configuration>
<property>
<name>fs.defaultFSname>
<value>hdfs://主机名:9000value>
property>
<property>
<name>hadoop.tmp.dirname>
<value>/opt/hadoop/tmpvalue>
property>
configuration>
<configuration>
<property>
<name>dfs.replicationname>
<value>1value>
property>
<property>
<name>dfs.namenode.name.dirname>
<value>file:///opt/hadoop/data/namenodevalue>
property>
<property>
<name>dfs.datanode.data.dirname>
<value>file:///opt/hadoop/data/datanodevalue>
property>
<property>
<name>dfs.permissionsname>
<value>falsevalue>
property>
configuration>
<configuration>
<property>
<name>mapreduce.framework.namename>
<value>yarnvalue>
property>
<property>
<name>mapreduce.jobhistory.addressname>
<value>主机名:10020value>
property>
<property>
<name>mapreduce.hobhistory.webapp.addressname>
<value>主机名:19888value>
property>
configuration>
<configuration>
<property>
<name>yarn.nodemanager.aux-servicesname>
<value>mapreduce_shufflevalue>
property>
configuration>
添加后两台主机的主机名(本机名为bigdata01)
例如:
bigdata02
bigdata03
scp -r /opt/hadoop root@主机名:/opt/ (传输hadoop整个文件夹)
传输已经配置好的全局变量/etc/profile到其他两台主机上(传输到其他两台主机上后需要自行生效才能生效source /etc/profile)
scp /etc/profile root@主机名:/etc/
在第一台主机上hadoop文件夹中创建data文件夹再在data文件夹中创建namenode和datanode(tmp文件夹可以自己创建也可以格式化后自动创建)
mkdir 命令创建
hdfs namenode -format
start-all.sh
第一台4个进程
第二台3个进程(datanode)
第三台3个进程(datanode)
hdfs dfs -mkdir /input
hdfs dfs -put /opt/hadoop/etc/hadoop /input