HADOOP-17358. Improve excessive reloading of Configurations (#2436)
Co-authored-by: ahussein <ahmed.hussein@verizonmedia.com> (cherry picked from commit71071e5c0f
) (cherry picked from commit23fe3bdab3
)
This commit is contained in:
parent
75c9aefe16
commit
ac3e10af63
|
@ -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);
|
||||||
|
|
|
@ -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");
|
||||||
|
|
Loading…
Reference in New Issue