Java操作Hadoop报java.net.ConnectException: Call From xxx to xxx.:9000 failed on connection exception错误

JAVA API 操作 HDFS出现连接错误:

java.net.ConnectException: Call From xxx to localhost:8020 failed on connection exception: java.net.ConnectException: Connection refused错误。

解决办法:

1、先检查了 core-site.xml,确定了配置的是端口无误。

2、检查虚拟机ip能不能ping通。

3、检查虚拟机防护墙是否开着。

 

以上步骤都没问题,还是不行,既然ip地址能ping通过,那么我把URI的localhost改成ip试试。

public static final String HDFS_PATH = "hdfs://x.x.x.x:9000";

结果还是不行。

4、修改core-site.xml中地址

core-site.xml中的地址我也得进行相应的修改:


   
        hdfs://x.x.x.x:9000
   

   
        hadoop.tmp.dir
        /home/japson/app/tmp
   

之后,就成了。
注意

这里我没有使用主机名,如果要使用主机名需要:
1. 确保宿主机上即windows上修改了hosts文件,主机名对应那个ip。
2. 修改虚拟机上的etc/hosts文件对应的主机名和ip关系。
3. hadoop的core-site.xml中涉及到localhost的改为主机名或者ip都行。

我现在不想要麻烦,使用了ip地址。有一个问题就是ip地址变化了,那么就需要改变2个地方:

    java中的URI
    hadoop的core-site.xml
 

你可能感兴趣的:(Hadoop)