使用ECS搭建hdfs启动时报java.net.BindException: Problem binding to [node01:9000] java.net.BindException异常

今天用阿里的服务器搭了个伪分布式的HDFS,格式化后启动hdfs,发现只有dataNode启动了,查看启动日志发现异常:

2019-01-22 15:54:50,507 FATAL org.apache.hadoop.hdfs.server.namenode.NameNode: Failed to start namenode.
java.net.BindException: Problem binding to [node01:9000] java.net.BindException: Cannot assign requested address; For more details see:  http://wiki.apache.org/hadoop/BindException
        at sun.reflect.NativeConstructorAccessorImpl.newInstance0(Native Method)
        at sun.reflect.NativeConstructorAccessorImpl.newInstance(NativeConstructorAccessorImpl.java:62)
        at sun.reflect.DelegatingConstructorAccessorImpl.newInstance(DelegatingConstructorAccessorImpl.java:45)
        at java.lang.reflect.Constructor.newInstance(Constructor.java:423)
        at org.apache.hadoop.net.NetUtils.wrapWithMessage(NetUtils.java:791)
        at org.apache.hadoop.net.NetUtils.wrapException(NetUtils.java:720)
        at org.apache.hadoop.ipc.Server.bind(Server.java:424)
        at org.apache.hadoop.ipc.Server$Listener.(Server.java:573)
        at org.apache.hadoop.ipc.Server.(Server.java:2206)
        at org.apache.hadoop.ipc.RPC$Server.(RPC.java:944)
        at org.apache.hadoop.ipc.ProtobufRpcEngine$Server.(ProtobufRpcEngine.java:537)
        at org.apache.hadoop.ipc.ProtobufRpcEngine.getServer(ProtobufRpcEngine.java:512)
        at org.apache.hadoop.ipc.RPC$Builder.build(RPC.java:789)
        at org.apache.hadoop.hdfs.server.namenode.NameNodeRpcServer.(NameNodeRpcServer.java:331)
        at org.apache.hadoop.hdfs.server.namenode.NameNode.createRpcServer(NameNode.java:627)
        at org.apache.hadoop.hdfs.server.namenode.NameNode.initialize(NameNode.java:600)
        at org.apache.hadoop.hdfs.server.namenode.NameNode.(NameNode.java:765)
        at org.apache.hadoop.hdfs.server.namenode.NameNode.(NameNode.java:749)
        at org.apache.hadoop.hdfs.server.namenode.NameNode.createNameNode(NameNode.java:1446)
        at org.apache.hadoop.hdfs.server.namenode.NameNode.main(NameNode.java:1512)

针对找个异常,首先是要确定自己的配置文件有没有配置错误,检查了一遍没错呀。然后就去官网看看什么原因(点击查看官网关于此异常介绍),官网上的内容如下:
在这里插入图片描述
根据官网介绍,出现这种情况要么是9000端口被占用了,要么就是hdfs在EC2上运行,那么hdfs服务将尝试使用公共主机名或IP显式绑定公共弹性IP地址,或者隐式使用“0.0.0.0”作为地址。

首先看看9000端口有没有被占用,输入官网提供的指令: netstat -a -t --numeric-ports -p,发现9000端口并没有被占用,那么就是第二个原因了。百度了一下阿里的ECS服务器无法绑定公网IP的地址,细心的人应该能发现连接服务器的ip和你连接服务器后,输入ifconfig显示的ip地址不一致。如下图,可以看到网段都不一样:
使用ECS搭建hdfs启动时报java.net.BindException: Problem binding to [node01:9000] java.net.BindException异常_第1张图片
所以要解决这个BindException,直接修改/etc/hosts文件:

内网IP地址  hostname1
公网IP地址  hostname2

使用ECS搭建hdfs启动时报java.net.BindException: Problem binding to [node01:9000] java.net.BindException异常_第2张图片

注意:内网IP对应的hostname要和hadoop的配置文件core-site.xml的hostname对应。


        fs.defaultFS
        hdfs://node01:9000


        hadoop.tmp.dir
        /var/abc/hadoop/local

修改完成后重新格式化,hdfs就可以正常启动了。

你可能感兴趣的:(大数据)