diff --git a/hadoop-common-project/hadoop-common/src/main/java/org/apache/hadoop/fs/viewfs/ViewFileSystemOverloadScheme.java b/hadoop-common-project/hadoop-common/src/main/java/org/apache/hadoop/fs/viewfs/ViewFileSystemOverloadScheme.java index 5353e93b6f..60d14d3851 100644 --- a/hadoop-common-project/hadoop-common/src/main/java/org/apache/hadoop/fs/viewfs/ViewFileSystemOverloadScheme.java +++ b/hadoop-common-project/hadoop-common/src/main/java/org/apache/hadoop/fs/viewfs/ViewFileSystemOverloadScheme.java @@ -97,7 +97,7 @@ import static org.apache.hadoop.fs.viewfs.Constants.CONFIG_VIEWFS_IGNORE_PORT_IN * the mount table name. * (3) If there are no mount links configured with the initializing uri's * hostname as the mount table name, then it will automatically consider the - * current uri as fallback( ex: fs.viewfs.mounttable..linkFallBack) + * current uri as fallback( ex: fs.viewfs.mounttable..linkFallback) * target fs uri. *****************************************************************************/ @InterfaceAudience.LimitedPrivate({ "MapReduce", "HBase", "Hive" }) @@ -354,4 +354,9 @@ public class ViewFileSystemOverloadScheme extends ViewFileSystem { .getMyFs(); } + @Override + @InterfaceAudience.LimitedPrivate("HDFS") + public URI canonicalizeUri(URI uri) { + return super.canonicalizeUri(uri); + } } \ No newline at end of file diff --git a/hadoop-hdfs-project/hadoop-hdfs-client/src/main/java/org/apache/hadoop/hdfs/ViewDistributedFileSystem.java b/hadoop-hdfs-project/hadoop-hdfs-client/src/main/java/org/apache/hadoop/hdfs/ViewDistributedFileSystem.java index 2894a244a4..70ba886b97 100644 --- a/hadoop-hdfs-project/hadoop-hdfs-client/src/main/java/org/apache/hadoop/hdfs/ViewDistributedFileSystem.java +++ b/hadoop-hdfs-project/hadoop-hdfs-client/src/main/java/org/apache/hadoop/hdfs/ViewDistributedFileSystem.java @@ -1072,16 +1072,7 @@ public class ViewDistributedFileSystem extends DistributedFileSystem { return super.canonicalizeUri(uri); } - ViewFileSystemOverloadScheme.MountPathInfo mountPathInfo = null; - try { - mountPathInfo = this.vfs.getMountPathInfo(new Path(uri), getConf()); - } catch (IOException e) { - LOGGER.warn("Failed to resolve the uri as mount path", e); - return null; - } - checkDFS(mountPathInfo.getTargetFs(), "canonicalizeUri"); - return ((DistributedFileSystem) mountPathInfo.getTargetFs()) - .canonicalizeUri(uri); + return vfs.canonicalizeUri(uri); } @Override