HADOOP-13140. FileSystem#initialize must not attempt to create StorageStatistics objects with null or empty schemes (Mingliang Liu via cmccabe)

(cherry picked from commit f2c1d9181f)
(cherry picked from commit feabfe9cda)

Conflicts:
	hadoop-common-project/hadoop-common/src/main/java/org/apache/hadoop/fs/FileSystem.java
This commit is contained in:
Colin Patrick Mccabe 2016-05-18 09:15:32 -07:00
parent ccb1cade5b
commit 7bbf42b82f
2 changed files with 16 additions and 2 deletions

View File

@ -75,6 +75,9 @@ import org.apache.htrace.core.TraceScope;
import com.google.common.annotations.VisibleForTesting; import com.google.common.annotations.VisibleForTesting;
import static com.google.common.base.Preconditions.checkArgument;
import static org.apache.hadoop.fs.CommonConfigurationKeysPublic.*;
/**************************************************************** /****************************************************************
* An abstract base class for a fairly generic filesystem. It * An abstract base class for a fairly generic filesystem. It
* may be implemented as a distributed filesystem, or as a "local" * may be implemented as a distributed filesystem, or as a "local"
@ -209,7 +212,13 @@ public abstract class FileSystem extends Configured implements Closeable {
* @param conf the configuration * @param conf the configuration
*/ */
public void initialize(URI name, Configuration conf) throws IOException { public void initialize(URI name, Configuration conf) throws IOException {
statistics = getStatistics(name.getScheme(), getClass()); final String scheme;
if (name.getScheme() == null || name.getScheme().isEmpty()) {
scheme = getDefaultUri(conf).getScheme();
} else {
scheme = name.getScheme();
}
statistics = getStatistics(scheme, getClass());
resolveSymlinks = conf.getBoolean( resolveSymlinks = conf.getBoolean(
CommonConfigurationKeys.FS_CLIENT_RESOLVE_REMOTE_SYMLINKS_KEY, CommonConfigurationKeys.FS_CLIENT_RESOLVE_REMOTE_SYMLINKS_KEY,
CommonConfigurationKeys.FS_CLIENT_RESOLVE_REMOTE_SYMLINKS_DEFAULT); CommonConfigurationKeys.FS_CLIENT_RESOLVE_REMOTE_SYMLINKS_DEFAULT);
@ -3469,6 +3478,8 @@ public abstract class FileSystem extends Configured implements Closeable {
@Deprecated @Deprecated
public static synchronized Statistics getStatistics(final String scheme, public static synchronized Statistics getStatistics(final String scheme,
Class<? extends FileSystem> cls) { Class<? extends FileSystem> cls) {
checkArgument(scheme != null,
"No statistics is allowed for a file system with null scheme!");
Statistics result = statisticsTable.get(cls); Statistics result = statisticsTable.get(cls);
if (result == null) { if (result == null) {
final Statistics newStats = new Statistics(scheme); final Statistics newStats = new Statistics(scheme);

View File

@ -23,6 +23,7 @@ import java.util.NavigableMap;
import java.util.NoSuchElementException; import java.util.NoSuchElementException;
import java.util.TreeMap; import java.util.TreeMap;
import com.google.common.base.Preconditions;
import org.apache.hadoop.classification.InterfaceAudience; import org.apache.hadoop.classification.InterfaceAudience;
/** /**
@ -55,7 +56,7 @@ public enum GlobalStorageStatistics {
* null if there is none. * null if there is none.
*/ */
public synchronized StorageStatistics get(String name) { public synchronized StorageStatistics get(String name) {
return map.get(name); return name == null ? null : map.get(name);
} }
/** /**
@ -70,6 +71,8 @@ public enum GlobalStorageStatistics {
*/ */
public synchronized StorageStatistics put(String name, public synchronized StorageStatistics put(String name,
StorageStatisticsProvider provider) { StorageStatisticsProvider provider) {
Preconditions.checkNotNull(name,
"Storage statistics can not have a null name!");
StorageStatistics stats = map.get(name); StorageStatistics stats = map.get(name);
if (stats != null) { if (stats != null) {
return stats; return stats;