Hadoop 在重启或者多次格式化后无法启动datanode问题的解决

一.安装好的hadoop,在重启或者多次格式化后无法重启datanode

通过查看日志出现下面错误提示:

2013-07-09 21:02:28,129 INFO org.apache.hadoop.hdfs.server.datanode.DataNode: PacketResponder 0 for block blk_4652602677290140246_1188 terminating
2013-07-09 21:05:52,576 INFO org.apache.hadoop.hdfs.server.datanode.DataBlockScanner: Verification succeeded for blk_4652602677290140246_1188
2013-07-09 21:12:37,713 WARN org.apache.hadoop.hdfs.server.datanode.DataNode: java.io.IOException: Call to long1657-06/192.168.0.6:9000 failed on local exception: java.io.EOFException
    at org.apache.hadoop.ipc.Client.wrapException(Client.java:775)
    at org.apache.hadoop.ipc.Client.call(Client.java:743)
    at org.apache.hadoop.ipc.RPC$Invoker.invoke(RPC.java:220)
    at com.sun.proxy.$Proxy4.sendHeartbeat(Unknown Source)
    at org.apache.hadoop.hdfs.server.datanode.DataNode.offerService(DataNode.java:702)
    at org.apache.hadoop.hdfs.server.datanode.DataNode.run(DataNode.java:1186)
    at java.lang.Thread.run(Thread.java:724)
Caused by: java.io.EOFException
    at java.io.DataInputStream.readInt(DataInputStream.java:392)
    at org.apache.hadoop.ipc.Client$Connection.receiveResponse(Client.java:501)
    at org.apache.hadoop.ipc.Client$Connection.run(Client.java:446)

二.问题产生原因
        当我们执行文件系统格式化时,会在namenode数据文件夹(即配置文件中dfs.name.dir在本地系统的路径)中保存一个current/VERSION文件,记录namespaceID,标识了所格式化的 namenode的版本。如果我们频繁的格式化namenode,那么datanode中保存(即配置文件中dfs.data.dir在本地系统的路径)的current/VERSION文件只是你第一次格式化时保存的namenode的namespaceID,因此就会造成datanode与namenode之间的namespaceID不一致。
三、解决办法
      把配置文件中dfs.data.dir在本地系统的路径下的current/VERSION中的namespaceID改为与namenode一样。

      如果还不行可以把namenode,datanode中的dfs.data.dir指定目录删除重新创建,然后再namenode中格式化:hadoop namenode -format

     启动hadoop就可以启动datanode节点了


  • 4
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值