系统环境
C.D.H 版本:6.2.0
hadoop 版本:3.0.0
集群环境:Linux CentOS7
①
.java.io.IOException: Port 9820 specified in URI hdfs://nameservice1:9820/user/root/.staging/job_1616116977910_0014/job.splitmetainfo but host ‘nameservice1’ is a logical (HA) namenode and does not use port information.
问题描述:
闲暇情况下,尝试用 C.D.H 搭建了一个Hadoop集群,所用版本是
6.2.0
,集群是跑在Linux虚拟机的,然后运行一个 简单的 mapreduce的任务,发现在虚拟机节点可以直接运行, 但是放到 windows下的IDE (这里用的是IDEA)中,报错:java.io.IOException: Port 9820 specified in URI hdfs://nameservice1:9820/user/root/.staging/job_1616116977910_0014/job.splitmetainfo but host 'nameservice1' is a logical (HA) namenode and does not use port information.
问题分析:
从错误日志看到,
nameservice1
是逻辑节点,没有使用到 9820 节点???
处理:起初以为是core-site.xml
的配置文件中的配置写错了,通过查看老哥们的博客说是,配置里面端口号不能写,但是因为我的配置文件是从CDH集群中直接取下来的,并没有端口在写。以下是真实的配置:
<property>
<name>fs.defaultFS</name>
<value>hdfs://nameservice1</value>
</property>
这就奇怪了,后来去查看源码,发现
if (checkPort && ((AbstractNNFailoverProxyProvider)providerNN).useLogicalURI()) {
int port = nameNodeUri.getPort();
if (port > 0 && port != 9820) {
throw new IOException("Port " + port + " specified in URI " + nameNodeUri +