HADOOP-17358. Improve excessive reloading of Configurations (#2436)

Co-authored-by: ahussein <ahmed.hussein@verizonmedia.com>
(cherry picked from commit 71071e5c0f)
(cherry picked from commit 23fe3bdab3)
This commit is contained in:
Ahmed Hussein 2020-11-11 14:39:03 -06:00 committed by Wei-Chiu Chuang
parent 75c9aefe16
commit ac3e10af63
2 changed files with 27 additions and 10 deletions

View File

@ -1005,11 +1005,11 @@ public class Configuration implements Iterable<Map.Entry<String,String>>,
properties = null; // trigger reload properties = null; // trigger reload
finalParameters.clear(); // clear site-limits finalParameters.clear(); // clear site-limits
} }
private synchronized void addResourceObject(Resource resource) { private synchronized void addResourceObject(Resource resource) {
resources.add(resource); // add to resources resources.add(resource); // add to resources
restrictSystemProps |= resource.isParserRestricted(); restrictSystemProps |= resource.isParserRestricted();
reloadConfiguration(); loadProps(properties, resources.size() - 1, false);
} }
private static final int MAX_SUBST = 20; private static final int MAX_SUBST = 20;
@ -2843,12 +2843,27 @@ public class Configuration implements Iterable<Map.Entry<String,String>>,
protected synchronized Properties getProps() { protected synchronized Properties getProps() {
if (properties == null) { if (properties == null) {
properties = new Properties(); properties = new Properties();
Map<String, String[]> backup = updatingResource != null ? loadProps(properties, 0, true);
new ConcurrentHashMap<String, String[]>(updatingResource) : null; }
loadResources(properties, resources, quietmode); return properties;
}
/**
* Loads the resource at a given index into the properties.
* @param props the object containing the loaded properties.
* @param startIdx the index where the new resource has been added.
* @param fullReload flag whether we do complete reload of the conf instead
* of just loading the new resource.
*/
private synchronized void loadProps(final Properties props,
final int startIdx, final boolean fullReload) {
if (props != null) {
Map<String, String[]> backup =
updatingResource != null
? new ConcurrentHashMap<>(updatingResource) : null;
loadResources(props, resources, startIdx, fullReload, quietmode);
if (overlay != null) { if (overlay != null) {
properties.putAll(overlay); props.putAll(overlay);
if (backup != null) { if (backup != null) {
for (Map.Entry<Object, Object> item : overlay.entrySet()) { for (Map.Entry<Object, Object> item : overlay.entrySet()) {
String key = (String) item.getKey(); String key = (String) item.getKey();
@ -2860,7 +2875,6 @@ public class Configuration implements Iterable<Map.Entry<String,String>>,
} }
} }
} }
return properties;
} }
/** /**
@ -2962,14 +2976,16 @@ public class Configuration implements Iterable<Map.Entry<String,String>>,
private void loadResources(Properties properties, private void loadResources(Properties properties,
ArrayList<Resource> resources, ArrayList<Resource> resources,
int startIdx,
boolean fullReload,
boolean quiet) { boolean quiet) {
if(loadDefaults) { if(loadDefaults && fullReload) {
for (String resource : defaultResources) { for (String resource : defaultResources) {
loadResource(properties, new Resource(resource, false), quiet); loadResource(properties, new Resource(resource, false), quiet);
} }
} }
for (int i = 0; i < resources.size(); i++) { for (int i = startIdx; i < resources.size(); i++) {
Resource ret = loadResource(properties, resources.get(i), quiet); Resource ret = loadResource(properties, resources.get(i), quiet);
if (ret != null) { if (ret != null) {
resources.set(i, ret); resources.set(i, ret);

View File

@ -53,8 +53,9 @@ public class TestConfigurationSubclass {
SubConf conf = new SubConf(true); SubConf conf = new SubConf(true);
conf.setQuietMode(false); conf.setQuietMode(false);
assertFalse(conf.isReloaded()); assertFalse(conf.isReloaded());
// adding a resource does not force a reload.
conf.addResource("not-a-valid-resource"); conf.addResource("not-a-valid-resource");
assertTrue(conf.isReloaded()); assertFalse(conf.isReloaded());
try { try {
Properties properties = conf.getProperties(); Properties properties = conf.getProperties();
fail("Should not have got here"); fail("Should not have got here");