HADOOP-17358. Improve excessive reloading of Configurations (#2436)
Co-authored-by: ahussein <ahmed.hussein@verizonmedia.com> (cherry picked from commit71071e5c0f
) (cherry picked from commit23fe3bdab3
) (cherry picked from commitac3e10af63
)
This commit is contained in:
parent
9f7553bab4
commit
487eaa6dea
|
@ -1005,11 +1005,11 @@ public class Configuration implements Iterable<Map.Entry<String,String>>,
|
|||
properties = null; // trigger reload
|
||||
finalParameters.clear(); // clear site-limits
|
||||
}
|
||||
|
||||
|
||||
private synchronized void addResourceObject(Resource resource) {
|
||||
resources.add(resource); // add to resources
|
||||
restrictSystemProps |= resource.isParserRestricted();
|
||||
reloadConfiguration();
|
||||
loadProps(properties, resources.size() - 1, false);
|
||||
}
|
||||
|
||||
private static final int MAX_SUBST = 20;
|
||||
|
@ -2843,12 +2843,27 @@ public class Configuration implements Iterable<Map.Entry<String,String>>,
|
|||
protected synchronized Properties getProps() {
|
||||
if (properties == null) {
|
||||
properties = new Properties();
|
||||
Map<String, String[]> backup = updatingResource != null ?
|
||||
new ConcurrentHashMap<String, String[]>(updatingResource) : null;
|
||||
loadResources(properties, resources, quietmode);
|
||||
loadProps(properties, 0, true);
|
||||
}
|
||||
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) {
|
||||
properties.putAll(overlay);
|
||||
props.putAll(overlay);
|
||||
if (backup != null) {
|
||||
for (Map.Entry<Object, Object> item : overlay.entrySet()) {
|
||||
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,
|
||||
ArrayList<Resource> resources,
|
||||
int startIdx,
|
||||
boolean fullReload,
|
||||
boolean quiet) {
|
||||
if(loadDefaults) {
|
||||
if(loadDefaults && fullReload) {
|
||||
for (String resource : defaultResources) {
|
||||
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);
|
||||
if (ret != null) {
|
||||
resources.set(i, ret);
|
||||
|
|
|
@ -53,8 +53,9 @@ public class TestConfigurationSubclass {
|
|||
SubConf conf = new SubConf(true);
|
||||
conf.setQuietMode(false);
|
||||
assertFalse(conf.isReloaded());
|
||||
// adding a resource does not force a reload.
|
||||
conf.addResource("not-a-valid-resource");
|
||||
assertTrue(conf.isReloaded());
|
||||
assertFalse(conf.isReloaded());
|
||||
try {
|
||||
Properties properties = conf.getProperties();
|
||||
fail("Should not have got here");
|
||||
|
|
Loading…
Reference in New Issue