Hadoop hdfs上传文件报错解决

如果大家在安装的时候遇到问题,或者按步骤安装完后却不能运行Hadoop,那么建议仔细查看日志信息,Hadoop记录了详尽的日志信息,日志文件保存在logs文件夹内。

无论是启动,还是以后会经常用到的MapReduce中的每一个job,以及HDFS等相关信息,Hadoop均存有日志文件以供分析。

报错命令:
在这里插入图片描述
该错误产生的原因:
NameNode和DataNode的namespaceID不一致,这个错误是很多人在安装时会遇到的
查看日志信息为:
java.io.IOException: Incompatible namespaceIDs in /root/tmp/dfs/data:
NameNode namespaceID = 1201462299; DataNode namespaceID = 389958745

hadoop 多次格式化format namenode 导致节点不能启动解决,出现这个问题的原因是多次格式化会导致节点的clusterID不一致

解决方法:

  1. 先停止所有启动的服务
    切换到hadoop的目录下
cd /usr/local/hadoop/sbin/stop-all.sh
  1. 删除core-site.xml 文件中配置的文件夹:注意如果集群操作则需要在每个机器上都要进行
rm -r /usr/local/hadoop/tmp

在这里插入图片描述

  1. 如果还没有成功 还可以进入hdfs文件夹下,删除name和data文件夹 命令和上面的一样

在这里插入图片描述

  1. 重新格式化
./bin/hdfs namenode -format
  1. 启动服务
./sbin/start-dfs.sh

在这里插入图片描述
下面这两种方法在实际应用中也可能会用到。

1)重启坏掉的DataNode或JobTracker。当Hadoop集群的某单个节点出现问题时,一般不必重启整个系统,只须重启这个节点,它会自动连入整个集群。
在坏死的节点上输入如下命令即可:
bin/Hadoop-daemon.sh start DataNode
bin/Hadoop-daemon.sh start jobtracker

2) 动态加入DataNode或TaskTracker。这个命令允许用户动态将某个节点加入集群中。
bin/Hadoop-daemon.sh --config ./conf start DataNode
bin/Hadoop-daemon.sh --config ./conf start tasktracker

  • 3
    点赞
  • 21
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值