hadoop 多次执行命令:
hadoop namenode -format后,发现再次启动hadoop后,datanode节点无法正常启动,出现错误代码如下:
could only be replicated to 0 nodes, instead of 1,产生这样的错误原因有多种,这里列举出以下四种常用的解决方法以供参考:
- 确保master(namenode) 、slaves(datanode)的防火墙已经关闭
- 确保DFS空间的使用情况
- Hadoop默认的hadoop.tmp.dir的路径为/tmp/hadoop-${user.name},而有的linux系统的/tmp目录文件系统的类型往往是Hadoop不支持的。
- 先后启动namenode、datanode
$hadoop-daemon.sh start namenode
$hadoop-daemon.sh start datanode
所以,我直接将hadoop目录下的data1,data2,datalog1,datalog2,logs共5个文件夹全部删除,这样也就不用再去考虑如何使多个文件夹中的namenodeID保持一致了,然后再执行
hadoop namenode -format
之后继续:start-all.sh
运行之后使用jps命令查看,发现datanode节点终于正常启动。