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之后,就成了。
注意
这里没有使用主机名,如果要使用主机名需要:
- 确保宿主机上即windows上修改了hosts文件,主机名对应那个ip。
- 修改虚拟机上的etc/hosts文件对应的主机名和ip关系。
- hadoop的core-site.xml中涉及到localhost的改为主机名或者ip都行。
有一个问题就是ip地址变化了,那么就需要改变2个地方:
java中的URI
hadoop的core-site.xml