HADOOP-13140. FileSystem#initialize must not attempt to create StorageStatistics objects with null or empty schemes (Mingliang Liu via cmccabe)
(cherry picked from commitf2c1d9181f
) (cherry picked from commitfeabfe9cda
) Conflicts: hadoop-common-project/hadoop-common/src/main/java/org/apache/hadoop/fs/FileSystem.java
This commit is contained in:
parent
ccb1cade5b
commit
7bbf42b82f
|
@ -75,6 +75,9 @@ import org.apache.htrace.core.TraceScope;
|
|||
|
||||
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
|
||||
* 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
|
||||
*/
|
||||
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(
|
||||
CommonConfigurationKeys.FS_CLIENT_RESOLVE_REMOTE_SYMLINKS_KEY,
|
||||
CommonConfigurationKeys.FS_CLIENT_RESOLVE_REMOTE_SYMLINKS_DEFAULT);
|
||||
|
@ -3469,6 +3478,8 @@ public abstract class FileSystem extends Configured implements Closeable {
|
|||
@Deprecated
|
||||
public static synchronized Statistics getStatistics(final String scheme,
|
||||
Class<? extends FileSystem> cls) {
|
||||
checkArgument(scheme != null,
|
||||
"No statistics is allowed for a file system with null scheme!");
|
||||
Statistics result = statisticsTable.get(cls);
|
||||
if (result == null) {
|
||||
final Statistics newStats = new Statistics(scheme);
|
||||
|
|
|
@ -23,6 +23,7 @@ import java.util.NavigableMap;
|
|||
import java.util.NoSuchElementException;
|
||||
import java.util.TreeMap;
|
||||
|
||||
import com.google.common.base.Preconditions;
|
||||
import org.apache.hadoop.classification.InterfaceAudience;
|
||||
|
||||
/**
|
||||
|
@ -55,7 +56,7 @@ public enum GlobalStorageStatistics {
|
|||
* null if there is none.
|
||||
*/
|
||||
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,
|
||||
StorageStatisticsProvider provider) {
|
||||
Preconditions.checkNotNull(name,
|
||||
"Storage statistics can not have a null name!");
|
||||
StorageStatistics stats = map.get(name);
|
||||
if (stats != null) {
|
||||
return stats;
|
||||
|
|
Loading…
Reference in New Issue