HDFS-14850. Optimize FileSystemAccessService#getFileSystemConfiguration. Contributed by Lisheng Sun.

(cherry picked from commit d8313b2274)
This commit is contained in:
Inigo Goiri 2019-09-28 17:20:44 -07:00 committed by Wei-Chiu Chuang
parent aa5dfb2f8a
commit bb1015719c
1 changed files with 13 additions and 8 deletions

View File

@ -136,6 +136,7 @@ public class FileSystemAccessService extends BaseService implements FileSystemAc
private Collection<String> nameNodeWhitelist; private Collection<String> nameNodeWhitelist;
Configuration serviceHadoopConf; Configuration serviceHadoopConf;
private Configuration fileSystemConf;
private AtomicInteger unmanagedFileSystems = new AtomicInteger(); private AtomicInteger unmanagedFileSystems = new AtomicInteger();
@ -188,6 +189,7 @@ public class FileSystemAccessService extends BaseService implements FileSystemAc
} }
try { try {
serviceHadoopConf = loadHadoopConf(hadoopConfDir); serviceHadoopConf = loadHadoopConf(hadoopConfDir);
fileSystemConf = getNewFileSystemConfiguration();
} catch (IOException ex) { } catch (IOException ex) {
throw new ServiceException(FileSystemAccessException.ERROR.H11, ex.toString(), ex); throw new ServiceException(FileSystemAccessException.ERROR.H11, ex.toString(), ex);
} }
@ -212,6 +214,16 @@ public class FileSystemAccessService extends BaseService implements FileSystemAc
return hadoopConf; return hadoopConf;
} }
private Configuration getNewFileSystemConfiguration() {
Configuration conf = new Configuration(true);
ConfigurationUtils.copy(serviceHadoopConf, conf);
conf.setBoolean(FILE_SYSTEM_SERVICE_CREATED, true);
// Force-clear server-side umask to make HttpFS match WebHDFS behavior
conf.set(FsPermission.UMASK_LABEL, "000");
return conf;
}
@Override @Override
public void postInit() throws ServiceException { public void postInit() throws ServiceException {
super.postInit(); super.postInit();
@ -397,14 +409,7 @@ public class FileSystemAccessService extends BaseService implements FileSystemAc
@Override @Override
public Configuration getFileSystemConfiguration() { public Configuration getFileSystemConfiguration() {
Configuration conf = new Configuration(true); return fileSystemConf;
ConfigurationUtils.copy(serviceHadoopConf, conf);
conf.setBoolean(FILE_SYSTEM_SERVICE_CREATED, true);
// Force-clear server-side umask to make HttpFS match WebHDFS behavior
conf.set(FsPermission.UMASK_LABEL, "000");
return conf;
} }
} }